201621123037 《Java程序设计》第9周学习总结
作业09-集合与泛型z
1. 本周学习总结
1.1 以你喜欢的方式(思维导图或其他)归纳总结集合与泛型相关内容。
这次改一个方式,就不用思维导图了,用图文结合方式来总结
1. Map三视图
- 键值: Set KeySet()
(利用Set存放,key唯一不可重复) - 值集合(不是Set): Collection values()
(利用collection存放,value可以重复) - 键/值对集:Set<Map.Entry<K,V>> entrySet()
2. 遍历键/值对集
代码见1.2中所述
3. Java8新增语法

4. 删除指定元素
总结见下1.2
1.2 选做:收集你认为有用的代码片段
- 遍历键/值对集
Map<String,String> map = new HashMap<String,String>();
for(Map.Entry<String, String> entry:map.entrySet()){
String key = entry.getKey();
Employee value = entry.getValue();
System.out.println("key="+key+", value = "+value);
}
- (List)删除指定元素
添加进入之后
for(int i = 0;i<integerList.size();i++){
if(integerList.get(i)<3)
integerList.remove(i);
}
这样会出现遍历跳过元素的现象,故改用以下方式:
for (int i=list.size()-1;i>=0;i--) {
if((list.get(i)).equals(str)){
list.remove(i);
}
}
采用倒序方式来逐个删除不会出现跳过元素现象。
2. 书面作业
本次作业题集集合
1. List中指定元素的删除(题集题目)
1.1 实验总结。并回答:列举至少2种在List中删除元素的方法。
答:
本题中
/以空格(单个或多个)为分隔符,将line中的元素抽取出来,放入一个List/
public static List convertStringToList(String line)
这个函数,重点在于将以空格为分隔符的元素取出放入List时,用str.next()方法来获取空格前的元素,同时Scanner不仅可以获取控制台输入的内容,还可以读取字符串,如:Scanner sc = new Scanner(line); 其中line是字符串
接下来的函数
/在list中移除掉与str内容相同的元素/
public static void remove(List list, String str)
有两种删除元素方法:
1. 方法一
for (int i=list.size()-1;i>=0;i--) { if((list.get(i)).equals(str)){
list.remove(i);
}
}
采用倒序方式来逐个删除重复元素,且杜绝了删除后下标改变导致的跳过元素问题。
PS:注意倒序时最大下标为list.size()-1
2. 方法二
for (int i = 0; i < list.size(); i++) {
if(list.get(i).equals(str)){
list.remove(i);
i--;
}
对比方法一,这是常规思考方法——正序遍历,但是容易出现跳过元素的问题。
解决方法:
将下边值i每次判断之后就'i--'退回前一个跳过的元素上即可。
2. 统计文字中的单词数量并按出现次数排序(题集题目)
2.1 伪代码(不得复制代码,否则扣分)
Map<String,Integer> wordmap = new TreeMap<>();
//创建map对象
while循环下
if(word.equals("!!!!!"))
break
else if(map.countiansKey(word))
map.put(word,map.get(word)+1) //重复+1
else
map.put(word,1) //未重复为初始的1
List<Map.Entry<String, Integer>> list = new ArrayList<Map.Entry<String, Integer>>(wordmap.entrySet());
//改成list对象
Collections.sort(list,new Comprartor<Map.Entry<String,Integer>>() ) {
//对第二个参数进行排序
进行排序比较
}
for(遍历list前十个)
list.get(i).toString() //输出
2.2 实验总结
答:
本题关键在于怎么在遍历的同时把单词放到Map对象中去。首要要判断是否“!!!!!”结尾,在此基础上,若存在就把value值+1,否则加入此单词,value值=1.
在然后就是将其转换为Collection对象来进行排序,这就用到了之前的comparator
3. 倒排索引(题集题目)
本题较难,做不出来不要紧。但一定要有自己的思考过程,要有提交结果。
3.1 截图你的代码运行结果

3.2 伪代码(不得复制代码,否则扣分)
答:
Map<String, ArrayList<Integer>> map = new TreeMap<String, ArrayList<Integer>>();
while (sc.hasNextLine()) {
if (str.equals("!!!!!"))
break;
else
if (str.length() == 0)
continue;
str1=str.split(" +");
for 遍历数组str1
if (map.get(str1[j]) == null)
添加到值中
else
不重复则添加值中
}
for 遍历输出(遍历输出函数方法见上1.2选作题)
f(wordmap.get(word) == null)
print("found 0 results")
else
print(要求输出的格式)
3.3 实验总结
答:
这道题注意,第一次的放入map对象时,要对内容进行备份,添加到List对象中以便后续查询的输出。
对输入的内容进行读取时,可以用nextline()读取整行,方便计算行数,其次对字符串整个进行str.split(" +");操作,形成字符数组方便逐个判断存放map对象中。
4.Stream与Lambda
编写一个Student类,属性为:
private Long id;
private String name;
private int age;
private Gender gender;//枚举类型
private boolean joinsACM; //是否参加过ACM比赛
创建一集合对象,如List,内有若干Student对象用于后面的测试。
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而不是抛出异常。(截图:出现学号)
答:
List<Student1> newStudent = student.stream().filter(e -> e!=null&&e.getId()>36L&&e.getName().equals("Qin")&&e.getAge()>18&&e.getGender()==Gender.Woman&&e.isJoinsACM()==true).collect(Collectors.toList());
运行结果:

(其实结果一样~)
5. 泛型类:GeneralStack
题集jmu-Java-05-集合之GeneralStack
5.1 GeneralStack接口的代码
public interface GeneralStack<E> {
E push(E item);
E pop();
E peek();
public boolean empty();
public int size();
}
5.2 结合本题与以前作业中的ArrayListIntegerStack相比,说明泛型有什么好处
答:
在之前作业中的ArrayListIntegerStack里,放进栈中的元素只能是Integer类型,其他类型元素则报错;现在的泛型则规避了这个局限性,使对于栈来说,不管内部存放的是什么类型的数据,基本操作与元素的具体类型都无关。
6. 选做:泛型方法
基础参考文件GenericMain,在此文件上进行修改。
6.1 编写方法max,该方法可以返回List中所有元素的最大值。List中的元素必须实现Comparable接口。编写的max方法需使得String max = max(strList)可以运行成功,其中strList为List类型。也能使得Integer maxInt = max(intList);运行成功,其中intList为List类型。注意:不得直接调用Collections.max函数。
6.2 选做:现有User类,其子类为StuUser,且均实现了Comparable接口。编写方法max1,基本功能同6.1,使得User user = max1(stuList);可以运行成功,其中stuList为List类型。也可使得Object user = max(stuList)运行成功。
6.3 选做:编写int myCompare(T o1, T o2, Comparator c)方法,该方法可以比较两个User对象,也可以比较两个StuUser对象,传入的比较器c既可以是Comparator,也可以是Comparator。注意:该方法声明未写全,请自行补全。
7. 选做:逆向最大匹配分词算法
集合实验文件中的第07次实验(集合).doc文件,里面的题目6.
7.1 写出伪代码(不得直接复制代码)
7.2 截图你的代码运行结果。
3.码云及PTA
题目集:jmu-Java-05-集合
3.1. 码云代码提交记录
在码云的项目中,依次选择“统计-Commits历史-设置时间段”, 然后搜索并截图

3.2 截图PTA题集完成情况图
需要有两张图(1. 排名图。2.PTA提交列表图)



3.3 统计本周完成的代码量
需要将每周的代码统计情况融合到一张表中。
自己的目标能实现吗?
看第一周作业写的总代码至少3000行,看样子之前定的太少了,准备继续加油期末写到五千行~

| 周次 | 总代码量 | 新增代码量 | 总文件数 | 新增文件数 |
|---|---|---|---|---|
| 1 | 0 | 0 | 0 | 0 |
| 2 | 0 | 0 | 0 | 0 |
| 3 | 0 | 0 | 0 | 0 |
| 4 | 0 | 0 | 0 | 0 |
| 5 | 1167 | 1167 | 26 | 26 |
| 6 | 1830 | 663 | 32 | 6 |
| 7 | 2282 | 452 | 45 | 13 |
| 8 | 2446 | 164 | 48 | 3 |
| 9 | 2774 | 328 | 56 | 8 |
| 10 | 3313 | 539 | 65 | 9 |
4. 评估自己对Java的理解程度
尝试从以下几个维度评估自己对Java的理解程度
| 维度 | 程度 |
|---|---|
| 语法 | PTA简单题目没有问题,但是复杂的需要百度很久解决,还有一些很长的题目会理解偏差,读题能力不够 |
| 面向对象设计能力 | 设计能力不强,就是做题还行,如果做系统或者联系生活,就会有无从下手,之前购物车就想法很好总是实现不了预想 |
| 应用能力 | 这个能力上述购物车预设达不到就体现出此项能力很欠缺 |
| 至今为止代码行数 | 3313行 |
201621123037 《Java程序设计》第9周学习总结的更多相关文章
- 20145213《Java程序设计》第九周学习总结
20145213<Java程序设计>第九周学习总结 教材学习总结 "五一"假期过得太快,就像龙卷风.没有一点点防备,就与Java博客撞个满怀.在这个普天同庆的节日里,根 ...
- 20145213《Java程序设计》第二周学习总结
20145213<Java程序设计>第二周学习总结 教材学习内容总结 本周娄老师给的任务是学习教材的第三章--基础语法.其实我觉得还蛮轻松的,因为在翻开厚重的书本,一股熟悉的气息扑面而来, ...
- 20145213《Java程序设计》第一周学习总结
20145213<Java程序设计>第一周学习总结 教材学习内容总结 期待了一个寒假,终于见识到了神秘的娄老师和他的Java课.虽说算不上金风玉露一相逢,没有胜却人间无数也是情理之中,但娄 ...
- 21045308刘昊阳 《Java程序设计》第九周学习总结
21045308刘昊阳 <Java程序设计>第九周学习总结 教材学习内容总结 第16章 整合数据库 16.1 JDBC入门 16.1.1 JDBC简介 数据库本身是个独立运行的应用程序 撰 ...
- 20145330孙文馨 《Java程序设计》第一周学习总结
20145330孙文馨 <Java程序设计>第一周学习总结 教材学习内容总结 刚开始拿到这么厚一本书说没有压力是不可能的,开始从头看觉得很陌生进入不了状态,就稍微会有一点焦虑的感觉.于是就 ...
- 20145337 《Java程序设计》第九周学习总结
20145337 <Java程序设计>第九周学习总结 教材学习内容总结 数据库本身是个独立运行的应用程序 撰写应用程序是利用通信协议对数据库进行指令交换,以进行数据的增删查找 JDBC可以 ...
- 20145337 《Java程序设计》第二周学习总结
20145337 <Java程序设计>第二周学习总结 教材学习内容总结 Java可分基本类型与类类型: 基本类型分整数(short.int.long).字节(byte).浮点数(float ...
- 20145218《Java程序设计》第一周学习总结
20145218 <Java程序设计>第一周学习总结 教材学习内容总结 今天下午看了Java学习的视频,感觉很是新奇,之前觉得Java学起来是艰难枯燥的,但通过第一章的学习觉得如果自己可以 ...
- 《Java程序设计》第九周学习总结
20145224 <Java程序设计>第九周学习总结 第十六章 整合数据库 JDBC入门 ·数据库本身是个独立运行的应用程序 ·撰写应用程序是利用通信协议对数据库进行指令交换,以进行数据的 ...
- 《Java程序设计》第二周学习总结
20145224陈颢文<Java程序设计>第二周学习总结 教材学习内容总结 一.类型.变量与运算符 1.类型 整数: 可细分为为short整数(占2字节),int整数(占4字节),long ...
随机推荐
- linux通过命令查找大文件
一:如果linux根分区使用量达到100%,会造成如下现象: root不能登录 系统不能正常启动 二:通过命令查找根分区内的大文件 1.du -sh /* 2>/dev/null | sort ...
- Oracle入门第四天(上)——表管理与数据处理
一.常见数据库对象 1.基本对象 对应的对象英文名参考:https://docs.oracle.com/cd/B19306_01/server.102/b14220/intro.htm#sthref6 ...
- # 第二周课堂实践以及MyOD
第二周课堂实践以及MyOD 之前使用的虚拟机出现问题被我删掉了,开始学着使用Mac系统自带的终端.在课堂上出现了问题,询问王雄老师也没有解决,课下先使用了实验楼环境进行实验,后来又在Mac重新进行了尝 ...
- linux Ubuntu Kali 安装flash
http://jingyan.baidu.com/article/fa4125accdeeec28ad709252.html
- [2016北京集训测试赛5]azelso-[概率/期望dp]
Description Solution 感谢大佬的博客https://www.cnblogs.com/ywwyww/p/8511141.html 定义dp[i]为[p[i],p[i+1])的期望经过 ...
- 使用Java Api 对HBase进行简单操作
/** * 功能:测试Hbase基本的增删改查操作 * Created by liuhuichao on 2016/12/5. */ public class HbaseCRUDTest { publ ...
- tidb测试环境安装,离线部署
1.环境以及规划 机器:centos7.5 ; 文件系统为ext4:内存16g:cpu8核,共三个节点: ip hostname roles --- tidb tipd tikv --- tidb t ...
- SpringBoot-08:SpringBoot采用json的方式实现前后台通用的配置文件
------------吾亦无他,唯手熟尔,谦卑若愚,好学若饥------------- 一.需求: 本篇博客是最近笔者做的一个项目,已经上线但是还在不断开发,有些页面上的配置,测试服务器和正式服务器 ...
- jsp命名规则
jsp也用驼峰规则命名即可,不要使用下划线,否则在tomcat中容易出现解析错误
- 用Micro:bit做床头灯
这是一个非常简单的项目,给孩子们介绍感应和控制,使用光敏电阻LDR作为光线传感器和床头灯的LED. 这也介绍了模拟输入的概念.数字输入为ON或OFF.只有0和1两种可能的条件.仿真输入是一系列可能值中 ...