1.2 选作:收集你认为有用的代码片断java
本次做业题集集合编程
1.1 实验总结
answer:
本题关键在于remove函数和covnertStringToList函数的编写,首先covnertStringToList函数中,关键语句Scanner scanner = new Scanner(Line);
,其余并没什么好讲的。而remove函数,须要用迭代器进行遍历,再使用迭代器自带remove函数来进行删除,在调用迭代器的remove时,须要先调用next方法String str = (String) iterator.next();
安全
2.1 伪代码(简单写出大致步骤)函数
answer:性能
遍历text的每个单词 创建map映射; if(str重复出现) 键值+1 else 键值=1
2 实验总结学习
answer:测试
本题用到TreeMap。其中使用到Collections.sort自定义排序,其中,Collections若是想对Map进行排序,能够将Map转化成List,List<Map.Entry<String, Integer>> list = new ArrayList<Map.Entry<String, Integer>>(tmap.entrySet());
进行排序。3d
3.1 截图你的提交结果(出现学号)
code
3.2 伪代码(简单写出大致步骤)对象
answer:
if (行中有关键字) 在关键字集合中加入行号 for (每次搜索) { if (表 == 0) System.out.println("found 0 results"); else { System.out.println(行);
3.3 实验总结
answer:
本题主要使用TreeMap<String, Set<Integer>> line = new TreeMap<String, Set<Integer>>();
,来完成查找功能,是用出现的关键字来肯定行号,以后用行号出现的次数来肯定输出,若是没查找到,输出found 0 results
。
#编写一个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中调用,而后输出结果。
answer:
关键代码:
运行结果:
4.2 使用java8中的stream(), filter(), collect()编写功能同4.1的函数,并测试。
answer:
运行结果:
4.3 构建测试集合的时候,除了正常的Student对象,再往集合中添加一些null,而后从新改写4.2,使其不出现异常。
answer:
5.1 截图你的提交结果(出现学号)
5.2 GeneralStack接口的代码
answer:
interface GeneralStack
public E push(E item);
ArrayList getList();
public E pop();
public E peek();
public boolean empty();
public int size();
}
3 结合本题,说明泛型有什么好处
answer:
1.类型安全。 2.消除强制类型转换。泛型的一个附带好处是,消除源代码中的许多强制类型转换。这使得代码更加可读,而且减小了出错机会。 3.潜在的性能收益。 对于这题来讲,本题的stack须要实现Interger、Double和Car三种类型,使用泛型后,就能够对任何引用类型的数据都适用,消除了强制的类型转换。
基础参考文件GenericMain,在此文件上进行修改。
6.1 编写方法max,该方法能够返回List中全部元素的最大值。List中的元素必须实现Comparable接口。编写的max方法需使得String max = max(strList)能够运行成功,其中strList为List
answer:
题目集:jmu-Java-05-集合
3.1. 码云代码提交记录
3.2. PTA实验