9
1. 本周学习总结
1.1 以你喜欢的方式(思维导图或其他)归纳总结集合与泛型相关内容。
2. 书面作业
本次作业题集集合
1. List中指定元素的删除(题集题目)
先建立一个scanner扫描器,通过next()方法就会自动将String根据空格断开。
1.1 实验总结。并回答:列举至少2种在List中删除元素的方法。
方法一:
for(int i=0;i<list.size();i++){
if(list.get(i)%2==0){
list.remove(i);
i--;
}
}
方法二:
for(int i=list.size()-1;i>=0;i--){
if(list.get(i)%2==0)
list.remove(i);
}
2. 统计文字中的单词数量并按出现次数排序(题集题目)
2.1 伪代码(不得复制代码,否则扣分)
创建 Map<String,Integer>
输入字符串String x;
判断是否遇到!!!!!
输出map的长度System.out.println(map.size());
将map对象转化成ArrayList()
用Collections.sort()对map进行排序;
输出前十的元素
2.2 实验总结
这道题用了Hashmap,用collection对List进行排序,注意的是在使用collection排序时要将其转化成Array List。
3. 倒排索引(题集题目)
本题较难,做不出来不要紧。但一定要有自己的思考过程,要有提交结果。
3.1 截图你的代码运行结果
3.2 伪代码(不得复制代码,否则扣分)
建立TreeMap<String, Set
用while判断输入以及!!!!!,存放单词和行数
whlie()循环解决匹配查询的单词以及输出单词对应的行数或者整行的单词
3.3 实验总结
先建立map存储单词,将单词放入键中,然后将单词出现的行数存入值中,然后根据i俺的大小排序。
4.Stream与Lambda
编写一个Student类,属性为:
private Long id;
private String name;
private int age;
private Gender gender;//枚举类型
private boolean joinsACM; //是否参加过ACM比赛
创建一集合对象,如List
4.1 使用传统方法编写一个搜索方法List search(List stuList, Long id, String name, int age, Gender gender, boolean joinsACM),然后调用该方法将id>某个值,name为某个值, age>某个值, gender为某个值,参加过ACM比赛的学生筛选出来,放入新的集合。在main中调用,然后输出结果。(截图:出现学号、姓名)
4.2 使用java8中的stream(), filter(), collect()编写功能同4.1的代码,并测试(要出现测试数据)。构建测试集合的时候,除了正常的Student对象,再往集合中添加一些null,你编写的方法应该能处理这些null而不是抛出异常。(截图:出现学号)
5. 泛型类:GeneralStack
题集jmu-Java-05-集合之GeneralStack
5.1 GeneralStack接口的代码
interface GeneralStack<T>{
T push(T item);
T pop();
T peek();
public boolean empty();
public int size();
}
5.2 结合本题与以前作业中的ArrayListIntegerStack相比,说明泛型有什么好处
定义类型时不用直接决定类型,不局限于某种类型,减少了出错,使用起来也更加灵活。
3.码云及PTA
题目集:jmu-Java-05-集合
3.1. 码云代码提交记录
3.2 截图PTA题集完成情况图
3.3 统计本周完成的代码量
周次 | 总代码量 | 新增代码量 | 总文件数 | 新增文件数 |
---|---|---|---|---|
1 | 86 | 86 | 8 | 8 |
2 | 342 | 342 | 10 | 10 |
3 | 762 | 762 | 16 | 16 |
4 | 762 | 0 | 16 | 0 |
5 | 1229 | 967 | 24 | 8 |
6 | 1752 | 523 | 29 | 5 |
7 | 2117 | 365 | 33 | 4 |
8 | 2493 | 376 | 36 | 3 |
9 | 2887 | 511 | 43 | 7 |
10 | 3152 | 265 | 47 | 4 |
4. 评估自己对Java的理解程度
维度 程度
写代码有点困难,感觉越学越难,很多不会写
面向对象设计能力 需要百度或者问同学
应用能力 一般般,简单一点的可以做一点
至今为止代码行数 3000多