1.本周学习总结

1.1思维导图

2.书面作业

Q1.List中指定元素的删除(题目4-1)

1.1 实验总结

总结:判断List中是否存在指定元素,需要用到equals方法,若存在就用remove进行对元素的删除。remove方法就是删除当前下标为i的元素,然后将该元素的所有元素向前移一位,i自减。

Q2.统计文字中的单词数量并按出现次数排序(题目5-3)

2.1 伪代码(简单写出大体步骤)

(1)创建HashMap对象Map<String,Integer> map = new HashMap<String,Integer>();
(2)统计字符出现次数,若为空,则为1;若不为空,则n+1;
(3)转化,Map转化为List;
(4)Collections.sort比较排序;
(5)输出十个;

2.2 实验总结

总结:首先此题要使用到HashMap,将字符串中的字符存入且没有重复。
(1)判断输入的字符是否为空,若为空,则赋值value=1;若不为空,则n+1;这里要用到Map中的get()、put()方法;
(2)List<Map.Entry<String, Integer>> entryList=new ArrayList();将Map转化为List,因为Collections.sort不能用在Map中;
(3)另外还需要使用到 Comparator中的Compare对字符进行按照value从大到小排序;

Q3.倒排索引(题目5-4)

3.1 截图你的提交结果(出现学号)

3.2 伪代码(简单写出大体步骤)

(1)构建TreeMap,用于存放单词和单词所在行数;
(2)split方法,将单词存在数组中;
(3)将数组与List<String> line比较,找出每个单词所在行数,存入Map中;
(4)遍历找关键字,若找到,则输出所在行数和所在行的一整句;若找不到,输出found 0 results。

3.3 实验总结

(1)Map、Set、List的使用;
(2)调用split方法将一句话根据空格分开存入数组中,在与原句进行查找所在行数;
我感觉这一题是PTA中最难的一题,若让我独立完成,我认为我做不出来,这一题是参考了同学的代码以及同学的讲解,但是还没有完完全全掌握,还需要再琢磨、修改。

Q4.Stream与Lambda

编写一个Student类,属性为:

private Long id;
private String name;
private int age;
private Gender gender;//枚举类型
private boolean joinsACM; //是否参加过ACM比赛

创建一集合对象,如List,内有若干Student对象用于后面的测试。

4.1 使用传统方法编写一个方法,将id>10,name为zhang, age>20, gender为女,参加过ACM比赛的学生筛选出来,放入新的集合。在main中调用,然后输出结果。

初始化:

list.add(new Student(15L,"cheng",19,getGender(1),true));
list.add(new Student(20L,"li",20,getGender(1),false));
list.add(new Student(15L,"zhang",21,getGender(2),true));
list.add(new Student(2L,"cheng",25,getGender(2),false));
list.add(new Student(20L,"li",18,getGender(1),false));

结果截图:

4.2 使用java8中的stream(), filter(), collect()编写功能同4.1的函数,并测试。

功能实现:

list2=list.stream().filter(s->10<s.getId()).collect(Collectors.toList());
list2=list2.stream().filter(s->"zhang".equals(s.getName())).collect(Collectors.toList());
list2=list2.stream().filter(s->20<s.getAge()).collect(Collectors.toList());
list2=list2.stream().filter(s->getGender(2).equals(s.getGender())).collect(Collectors.toList());
list2=list2.stream().filter(s->s.isJoinsACM()==true).collect(Collectors.toList());

结果截图:

4.3 构建测试集合的时候,除了正常的Student对象,再往集合中添加一些null,然后重新改写4.2,使其不出现异常。

增加null:

list.add(null);

功能实现,增加排除null的情况:

list=list.stream().filter(s->s!=null).collect(Collectors.toList());

结果截图:

Q5.泛型类:GeneralStack(题目5-5)

5.1 截图你的提交结果(出现学号)

5.2 GeneralStack接口的代码

interface GeneralStack<T> {
T push(T item);
T pop();
T peek();
public boolean empty();
public int size();
}

5.3 结合本题,说明泛型有什么好处

好处:使用泛型可以不必直接决定类的类型,此题中对于Integer, Double, Car三个引用类型的栈,若不使用泛型接口则需要写三个不同类型的栈,若直接使用一个泛型接口,让Integer, Double, Car三个引用类型的栈都适用,则可以少写很多代码。

Q6.泛型方法

基础参考文件GenericMain,在此文件上进行修改。

6.1 编写方法max,该方法可以返回List中所有元素的最大值。List中的元素必须实现Comparable接口。编写的max方法需使得String max = max(strList)可以运行成功,其中strList为List类型。也能使得Integer maxInt = max(intList);运行成功,其中intList为List类型。

public class Max {

    public static void main(String[] args) {
List<String> strList = new ArrayList<String>();
List<Integer> intList = new ArrayList<Integer>();
strList.add("a");
strList.add("b");
strList.add("e");
intList.add(2);
intList.add(4);
intList.add(6);
String max = max(strList);
Integer maxInt = max(intList);
System.out.println("max = " + max);
System.out.println("maxInt =" + maxInt);
} public static <T extends Comparable<T>> T max(List<T> list) {
T max = list.get(0);
for(T i : list){
if(i.compareTo(max)>0)
max = i;
}
return max;
}
}

3.码云上代码提交记录及PTA实验总结

3.1码云代码提交记录

201521123027 <java程序设计>第八周学习总结的更多相关文章

  1. 201521123027 <java程序设计>第13周学习总结

    1.本周学习总结 以你喜欢的方式(思维导图.OneNote或其他)归纳总结多网络相关内容. 2.书面作业 1. 网络基础 1.1 比较ping www.baidu.com与ping cec.jmu.e ...

  2. 201521123027 <java程序设计>第11周学习总结

    1.本周学习总结 1.1 以你喜欢的方式(思维导图或其他)归纳总结多线程相关内容. 2.书面作业 1.互斥访问与同步访问 完成题集4-4(互斥访问)与4-5(同步访问) 1.1 除了使用synchro ...

  3. 201521123027 <java程序设计>第七周学习总结

    1.本周学习总结 2.书面作业 Q1.ArrayList代码分析 1.1 解释ArrayList的contains源代码 答: 源代码: //contains()方法 public boolean c ...

  4. 201521123027 <java程序设计>第十周学习总结

    1.本周学习总结 1.1 以你喜欢的方式(思维导图或其他)归纳总结异常与多线程相关内容. 异常: 多线程: 2.书面作业 Q1.finally 题目4-2 1.1 截图你的提交结果(出现学号) 1.2 ...

  5. 201571030332 扎西平措 《面向对象程序设计Java》第八周学习总结

    <面向对象程序设计Java>第八周学习总结   项目 内容 这个作业属于哪个课程 https://www.cnblogs.com/nwnu-daizh/ 这个作业的要求在哪里 https: ...

  6. 201871010106-丁宣元 《面向对象程序设计(java)》第八周学习总结

    201871010106-丁宣元 <面向对象程序设计(java)>第八周学习总结 正文开头: 项目 内容 这个作业属于哪个课程 https://home.cnblogs.com/u/nwn ...

  7. 20145213《Java程序设计》第九周学习总结

    20145213<Java程序设计>第九周学习总结 教材学习总结 "五一"假期过得太快,就像龙卷风.没有一点点防备,就与Java博客撞个满怀.在这个普天同庆的节日里,根 ...

  8. 21045308刘昊阳 《Java程序设计》第九周学习总结

    21045308刘昊阳 <Java程序设计>第九周学习总结 教材学习内容总结 第16章 整合数据库 16.1 JDBC入门 16.1.1 JDBC简介 数据库本身是个独立运行的应用程序 撰 ...

  9. 20145236 《Java程序设计》第九周学习总结

    20145236 <Java程序设计>第九周学习总结 教材学习内容总结 第十六章 整合数据库 JDBC简介 1.JDBC是java联机数据库的标准规范.它定义了一组标准类与接口,标准API ...

随机推荐

  1. 再起航,我的学习笔记之JavaScript设计模式06(抽象工厂模式)

    我的学习笔记是根据我的学习情况来定期更新的,预计2-3天更新一章,主要是给大家分享一下,我所学到的知识,如果有什么错误请在评论中指点出来,我一定虚心接受,那么废话不多说开始我们今天的学习分享吧! 前两 ...

  2. Linux操作系统-命令-free

    在看过网友写的一篇名为<Buffer和Cache的区别>http://zhumeng8337797.blog.163.com/blog/static/1007689142011102447 ...

  3. webpack 引入 bootstrap

    Bootstrap中是一种事实上的界面标准,标准到现在的网站大量的使用它.如果可以使用webpack引入的bootstrap,就可以一个npm install完成项目的依赖,而不必手工的添加到html ...

  4. Windows开发笔记-错误处理

    Windows函数为开发者提供了错误代码,这样当调用Windows函数失败后,可以通过查看错误代码了解错误信息.相应的错误与主调线程关联在一起,这种机制使得不同的线程能够独立运行而不会相互干扰.调用G ...

  5. android 学习 ListView使用补充

    前面两篇学习适配器的时候用的就是listview,主要是简单的添加,今晚在看了下listview滚动状态事件和动态加载数据,一个小demo. listview的滚动状态主要有三种,onScrollSt ...

  6. IOS数据持久化之归档NSKeyedArchiver

    IOS数据持久化的方式分为三种: 属性列表 (自定义的Property List .NSUserDefaults) 归档 (NSKeyedArchiver) 数据库 (SQLite.Core Data ...

  7. 2017多校第9场 HDU 6161 Big binary tree 思维,类似字典树

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=6161 题意: 题目是给一棵完全二叉树,从上到下从左到右给每个节点标号,每个点有权值,初始权值为其标号, ...

  8. Wdatepicker日期控件的使用指南 (转)

    Wdatepicker日期控件的使用指南 标签: inputclass语言functionstring正则表达式 2012-02-10 15:48 40826人阅读 评论(5) 收藏 举报 .embo ...

  9. Words used when reading Redis documents

    Redis-----------------First pageevolution n.演变,进化,发展 closely adv.紧密地trade off 交换物品,权衡achieved adj.高度 ...

  10. 接口测试之postman简介

    很长时间没有用postman了,今天趁着有点时间,对这个接口测试的利器从以下几个方面简单回顾下. 1.postman介绍 2.Postman安装 3.Postman建立.管理.回放请求 4.Postm ...