码迷,mamicode.com
首页 > 编程语言 > 详细

201521123087《Java程序设计》 第八周学习总结

时间:2017-04-15 20:37:51      阅读:278      评论:0      收藏:0      [点我收藏+]

标签:list   lines   put   修改   and   new   作业   str   java8   

1. 本周学习总结

技术分享

 

2. 书面作业

本次作业题集集合

  1. List中指定元素的删除(题目4-1)
    1.1 实验总结                                                                                                                                                                                                                                                答: 在实验中,Scanner的不止是只有System.in(键盘输入之类的),还可以是一个已赋值变量,如: Scanner in=new Scanner(nextLine);

  2. 统计文字中的单词数量并按出现次数排序(题目5-3)
    2.1 伪代码(简单写出大体步骤)                                                                                                                                                                                                                      答:

     遍历text的每一个单词
            建立map映射;
            if(str重复出现)
                键值+1
            else
            键值=1

    2.2 实验总结                                                                                                                                                                                                                                                  答:本题用到TreeMap。其中使用到Collections.sort自定义排序,其中,Collections如果想对Map进行排序,可以将Map转化成List,List<Map.Entry<String, Integer>> list = new ArrayList<Map.Entry<String, Integer>>(tmap.entrySet());进行排序。

  3. 倒排索引(题目5-4)
    3.1 截图你的提交结果(出现学号)
    3.2 伪代码(简单写出大体步骤)
    3.3 实验总结

  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中调用,然后输出结果。                                 答:

    • 方法如下:
      技术分享

    结果如下:
    技术分享


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

    • 起先不太会用,就上网查询了下得到了个类似功能的代码为:
      List<String> result1 = lines.stream() // convert list to stream
      .filter(line -> !"mkyong".equals(line)) // filter the line which equals to "mkyong"
      .collect(Collectors.toList()); // collect the output and convert streams to a list

    根据注释知道了代码含义,然后按照这个改写成功并测试结果如4.1所示,具体代码如下:

    技术分享


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

    • 由于我们知道listlist是可以存放null的,当我们添加null之后,该怎么不要让null影响到结果,其实就在判断条件那里加上!=null就行啦,具体代码如下。

    技术分享


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

  5. 泛型类:GeneralStack(题目5-5)
    5.1 截图你的提交结果(出现学号)
    5.2 GeneralStack接口的代码
    5.3 结合本题,说明泛型有什么好处

  6. 泛型方法
    基础参考文件GenericMain,在此文件上进行修改。
    6.1 编写方法max,该方法可以返回List中所有元素的最大值。List中的元素必须实现Comparable接口。编写的max方法需使得String max = max(strList)可以运行成功,其中strList为List<String>类型。也能使得Integer maxInt = max(intList);运行成功,其中intList为List<Integer>类型。
    答:

    private static <T> T max(List<T> list) {
             Collections.sort(list,new Comparator<T>()
             {
                @Override
                public int compare(T o1, T o2) {
                    
                        return o1.toString().compareTo(o2.toString());
                }
            }
         );
            return list.get(list.size()-1);
        }
    
    
    • 用Collections.max:
    
    
        public static <T extends Object & Comparable<? super T>> T max(Collection<? extends T> coll) 
        {
            return Collections.max(coll);
        }
    
    

    运行结果:
    技术分享

      • 最开始的时候用简单的泛型,因为只有String和Integer类型就直接将元素转换成String类再进行比较,但是如果是其他类型运行就会出错。
      • Collections自带求max的方法,用起来比较方便

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

题目集:jmu-Java-05-集合

3.1. 码云代码提交记录

  • 在码云的项目中,依次选择“统计-Commits历史-设置时间段”, 然后搜索并截图

3.2. PTA实验

 

201521123087《Java程序设计》 第八周学习总结

标签:list   lines   put   修改   and   new   作业   str   java8   

原文地址:http://www.cnblogs.com/jbc1132/p/6715192.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!