1. 本周学习总结

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

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

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

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

2. 书面作业

本次作业题集集合

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

1.1 实验总结

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


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

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

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

2.2 实验总结

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


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

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

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

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

3.3 实验总结

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

4.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中调用,然后输出结果

            enum Gender{
    male,female;
        }
    class Student{        //类的定义
    private Long id;
    private String name;
    private int age;
    private Gender gender;//枚举类型
    private boolean joinsACM; //是否参加过ACM比赛

            public static List<student> find(List<Student> list){        //find方法
    List<Student> list1 = new ArrayList<Student>();
    for(Student student : list){                                //遍历list数组然后筛选
    if(Student.id>10&&Student.name.equals("zhang")&&
            Student.age>20&&Student.gender==Student.female&&Student.joinsACM){
    list1.add(student)
    }
    }
        return list1;

            public static void main(String[] args) {        //main 函数
    List<Student> list = new ArrayList<Student>();
    list.add(... ... );                            //举例添加
    list.add(... ... );
    System.out.println(find(list));

        }

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

    List<Student> list2 = (ArrayList<Student>) list.stream().filter
    (Student->(... ... 判断的条件)).collect(Collectors.toList());
    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>类型

    public static <T extends Comparable> T max(List<T>list){
T Max = list.get(0);
for(T i : list){
    if(i.compareTo(Max)>0) Max = i;
}
return Max;
    }

    public class GenericMain {

public void main(String[] args) {
    ArrayList<String> arraylist = new ArrayList<String>();
    arraylist.add("B");
    arraylist.add("C");
    arraylist.add("D");
    System.out.println(max(arraylist));

}


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. css小随笔(二)与通用样式

    51先在学校HTML5已经有半个多月了,然后这个星期做了一个京东的手机网站,接触到了通用样式,下面以京东的手机站为例 这两个就是京东手机站了的不同的两个板块,因为HTML5仅仅只是学完了基本标签跟cs ...

  2. [您有新的未分配科技点]无旋treap:从好奇到入门(例题:bzoj3224 普通平衡树)

    今天我们来学习一种新的数据结构:无旋treap.它和splay一样支持区间操作,和treap一样简单易懂,同时还支持可持久化. 无旋treap的节点定义和treap一样,都要同时满足树性质和堆性质,我 ...

  3. 用分治法解决最近点对问题:python实现

    最近点对问题:给定平面上n个点,找其中的一对点,使得在n个点的所有点对中,该点对的距离最小.需要说明的是理论上最近点对并不止一对,但是无论是寻找全部还是仅寻找其中之一,其原理没有区别,仅需略作改造即可 ...

  4. Maven注意事项

    Maven好处: 1.依赖管理:对jar包统一管理 2.项目构建:项目编码完成后,对项目进行编译.测试.打包.部署,实现项目一键发布1.配置环境变量    注意:maven工具必须有jdk环境.并且: ...

  5. 使用jQuery实现简单的tab框

    html代码 <!DOCTYPE html><html><head> <meta charset="utf-8"> <meta ...

  6. 连上Wi-Fi 热点自动弹窗的实现方法

    当我们连上某个热点, 自动弹出登录窗口的专业名称叫做: Captive portal 原理, 实现方式有三种 1 : dns 跳转, 在热点上面实现配置, 把所有dns请求返回都配置为:服务器地址 : ...

  7. webpack打包体积优化

    优化: 1:外部引入模块(cdn)     如 jquery,zepto,d3, bootstrap这些固定的lib 使用cdn直接引用就可以,没有必要打包到build,有效利用302. 2:图标优化 ...

  8. windbg内存查看(d*)

    d*命令 d{a|b|c|d|D|f|p|q|u|w|W} Address [/c ColumuWidth] [l Length] Address:查看address地址处的内存. ColumnWid ...

  9. Andrew Ng机器学习课程笔记--week8(K-means&PCA)

    Unsupervised Learning 本周我们讲学习非监督学习算法,会学习到如下概念 聚类(clustering) PCA(Principal Componets Analysis主成分分析), ...

  10. hdu3416 Marriage Match IV(最短路+网络流)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=3416 题意: 给出含n个点.m条有向边的图,每条边只能走一次,给出起点和终点,求起点到终点的最短路径有 ...