1. 本周学习总结

1.1 以你喜欢的方式(思维导图或其他)归纳总结集合与泛型相关内容。

1.2 选做:收集你认为有用的代码片段

在做PTA5.3的时候一段看起来比较复杂的代码:

  1. List<Entry<String,Integer>> list =new ArrayList<Entry<String,Integer>>(map.entrySet());
  2. Collections.sort(list, new Comparator<Map.Entry<String, Integer>>()

2. 书面作业

本次作业题集集合

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

1.1 实验总结

  • 需要对list进行类型定义,在后面使用的时候则可以不进行强制转换
  • 使用remove删除的时候,删完后应该减1,元素往前移一个单位


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

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

  1. input sc
  2. if map contain sc Integer+1;
  3. else put(sc,1);
  4. sort the list(value and key);
  5. print the list;

2.2 实验总结

这里使用HashMap对输入的函数进行插入操作和计数,然后将其放入ArrayList中进行sort,通过entrySet操作返回键值对(String ,Integer)。


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

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

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

  1. TreeMap<String,TreeSet<Integer>> treemap;
  2. split nextLine;
  3. if treemap contain ,add num;
  4. else put(String ,num);
  5. printf get.key+get.value;
  6. if treeset=null or isEmpty;
  7. printf find 0 result;
  8. else printf treeset;

3.3 实验总结

  • 在输入的时候先用 string 输入,然后用split将其分成字符串数组。
  • 做行数的时候在循环末尾加一个count++,使下一个输入的行列变成第二行。
  • 输出部分要进行分情况考虑:输入为空的、一个都找不到的、只找到一个的和两个都找到的。

4.Stream与Lambda

编写一个Student类,属性为:

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

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

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

  1. enum Gender{
  2. male,female;
  3. }
  4. class Student{ //类的定义
  5. private Long id;
  6. private String name;
  7. private int age;
  8. private Gender gender;//枚举类型
  9. private boolean joinsACM; //是否参加过ACM比赛
  10. public static List<student> find(List<Student> list){ //find方法
  11. List<Student> list1 = new ArrayList<Student>();
  12. for(Student student : list){ //遍历list数组然后筛选
  13. if(Student.id>10&&Student.name.equals("zhang")&&
  14. Student.age>20&&Student.gender==Student.female&&Student.joinsACM){
  15. list1.add(student)
  16. }
  17. }
  18. return list1;
  19. public static void main(String[] args) { //main 函数
  20. List<Student> list = new ArrayList<Student>();
  21. list.add(... ... ); //举例添加
  22. list.add(... ... );
  23. System.out.println(find(list));
  24. }

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

  1. List<Student> list2 = (ArrayList<Student>) list.stream().filter
  2. (Student->(... ... 判断的条件)).collect(Collectors.toList());
  3. System.out.println(list2);

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

在筛选之前加一个判断student != null用来判断非空即可。


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

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

5.2 GeneralStack接口的代码

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

  • 使用泛型编写代码,可以被不同类型的对象使用,不在被限制于某一个类型。
  • 在本题中,栈变量stack有Integer、Double、Car三个选项,都可以使用GeneralStack的实现类ArrayListGeneralStack,而不需要每个类型都要去写一个方法完全相同而数据类型不同的实现类接口。
  • 泛型还有一个好处就是避免了强制转换发生的错误,如果写错了在编译阶段就编译不过去。

6.泛型方法

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

  1. public static <T extends Comparable> T max(List<T>list){
  2. T Max = list.get(0);
  3. for(T i : list){
  4. if(i.compareTo(Max)>0) Max = i;
  5. }
  6. return Max;
  7. }
  8. public class GenericMain {
  9. public void main(String[] args) {
  10. ArrayList<String> arraylist = new ArrayList<String>();
  11. arraylist.add("B");
  12. arraylist.add("C");
  13. arraylist.add("D");
  14. System.out.println(max(arraylist));
  15. }


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

3.1. 码云代码提交记录

201521123112《Java程序设计》第8周学习总结的更多相关文章

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

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

  2. 20145213《Java程序设计》第二周学习总结

    20145213<Java程序设计>第二周学习总结 教材学习内容总结 本周娄老师给的任务是学习教材的第三章--基础语法.其实我觉得还蛮轻松的,因为在翻开厚重的书本,一股熟悉的气息扑面而来, ...

  3. 20145213《Java程序设计》第一周学习总结

    20145213<Java程序设计>第一周学习总结 教材学习内容总结 期待了一个寒假,终于见识到了神秘的娄老师和他的Java课.虽说算不上金风玉露一相逢,没有胜却人间无数也是情理之中,但娄 ...

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

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

  5. 20145330孙文馨 《Java程序设计》第一周学习总结

    20145330孙文馨 <Java程序设计>第一周学习总结 教材学习内容总结 刚开始拿到这么厚一本书说没有压力是不可能的,开始从头看觉得很陌生进入不了状态,就稍微会有一点焦虑的感觉.于是就 ...

  6. 20145337 《Java程序设计》第九周学习总结

    20145337 <Java程序设计>第九周学习总结 教材学习内容总结 数据库本身是个独立运行的应用程序 撰写应用程序是利用通信协议对数据库进行指令交换,以进行数据的增删查找 JDBC可以 ...

  7. 20145337 《Java程序设计》第二周学习总结

    20145337 <Java程序设计>第二周学习总结 教材学习内容总结 Java可分基本类型与类类型: 基本类型分整数(short.int.long).字节(byte).浮点数(float ...

  8. 20145218《Java程序设计》第一周学习总结

    20145218 <Java程序设计>第一周学习总结 教材学习内容总结 今天下午看了Java学习的视频,感觉很是新奇,之前觉得Java学起来是艰难枯燥的,但通过第一章的学习觉得如果自己可以 ...

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

    20145224 <Java程序设计>第九周学习总结 第十六章 整合数据库 JDBC入门 ·数据库本身是个独立运行的应用程序 ·撰写应用程序是利用通信协议对数据库进行指令交换,以进行数据的 ...

  10. 《Java程序设计》第二周学习总结

    20145224陈颢文<Java程序设计>第二周学习总结 教材学习内容总结 一.类型.变量与运算符 1.类型 整数: 可细分为为short整数(占2字节),int整数(占4字节),long ...

随机推荐

  1. NYOJ116 士兵杀敌(二)

    士兵杀敌(二) 时间限制:1000 ms  |  内存限制:65535 KB 难度:5   描述 南将军手下有N个士兵,分别编号1到N,这些士兵的杀敌数都是已知的. 小工是南将军手下的军师,南将军经常 ...

  2. [填坑]树上差分 例题:[JLOI2014]松鼠的新家(LCA)

    今天算是把LCA这个坑填上了一点点,又复习(其实是预习)了一下树上差分.其实普通的差分我还是会的,树上的嘛,也是懂原理的就是没怎么打过. 我们先来把树上差分能做到的看一下: 1.找所有路径公共覆盖的边 ...

  3. Aleta病毒

    文件一定要及时备份!!! 文件一定要及时备份!!! 文件一定要及时备份!!! 文件一定要及时备份!!! 文件一定要及时备份!!! 文件一定要及时备份!!! 文件一定要及时备份!!! 文件一定要及时备份 ...

  4. Angular 小试牛刀[1]:Getting Started

    首先,Angular2 与 Angular1.x 版本没有多大关系,甚至可以说是两个完全不一样的框架,故 Angular 指的是 Angular2 及以上的版本.而 Angular 与 TypeScr ...

  5. MySQL执行计划extra中的using index 和 using where using index 的区别

    本文出处:http://www.cnblogs.com/wy123/p/7366486.html (保留出处并非什么原创作品权利,本人拙作还远远达不到,仅仅是为了链接到原文,因为后续对可能存在的一些错 ...

  6. 运行和控制Nginx

    Nginx命令行选项 启动.停止.重启nginx命令 如何重新加载nginx配置文件 nginx程序不重启平滑升级可执行文件   nginx命令行参数 不像许多其他软件系统,Nginx 仅有几个命令行 ...

  7. 关于JS中数组的分析操作

    JS数组的基础操作代码: <script type="text/javascript">        数组的三种定义    var arr1 = new Array( ...

  8. vue-cli安装

    近期梳理了一下win和linux下安装vue项目,总结一下,希望对于看的人有帮助,废话不多说. Linux下安装 因为我用的是deepin,所以再此就不演示了.首先电脑上已经安装好了node和npm了 ...

  9. ubuntu安装新版QQ

    我一直无法解决Ubuntu QQ问题,而最近我重装ubuntu之后在网络上找到与QQ相关的内容,网上有大神开发出了新版的wineQQ,解决了我们对QQ的需求.经过尝试,完成了QQ安装 如图 安装的是w ...

  10. salesforce零基础学习(七十九)简单排序浅谈 篇一

    我们在程序中经常需要对数据列表进行排序,有时候使用SOQL的order by 不一定能完全符合需求,需要对数据进行排序,排序可以有多种方式,不同的方式针对不同的场景.篇一只是简单的描述一下选择排序,插 ...