博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
201521123095 《Java程序设计》第8周学习总结
阅读量:5331 次
发布时间:2019-06-14

本文共 3655 字,大约阅读时间需要 12 分钟。

1. 本周学习总结

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

1109865-20170415192608751-1750427200.png

2. 书面作业

本次作业题集集合

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

1.1 实验总结

对于删除函数,用contains方法查看是否存在,如果找到了,删除后,list的长度就减一了,此时循环计数i也要减一。利用charAt得到的字符类型数据如果变为字符串以及注意到在删除元素后遍历下标要减1即可。

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

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

while (input.hasNextLine()) {            String str = input.next();            if (str.equals("!!!!!")){                break;}            else if (!str.contains(str))                str.add(str);        }

2.2 实验总结

这题关键就是使用了Set的自然排序实现类TreeSet,此类可以对添加的对象进行默认排序。

Q3 倒排索引(题目5-4)

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

1109865-20170415202248064-2078602846.png

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

while (!lineword.equals("!!!!!")) {    String[] words = lineword.split(" ");    for (String word : words) {        Set
subIndex = new TreeSet
(); if (!index.containsKey(word)) { subIndex.add(line); index.put(word, subIndex); } else { subIndex = index.get(word); if (!subIndex.contains(line)) { subIndex.add(line); index.put(word, subIndex); } }}

3.3 实验总结

要正确地处理Map内部的键值对的各类操作,在读每一行时候,用一个map映射,存放这一整行的信息和行数,读取每一行的每个单词,放入key为String, value为TreeSet
,即出现的行数。输出部分也要注意考虑。

Q4 Stream与Lambda

编写一个Student类,属性为:

private Long id;
private int age;
private Gender gender;//枚举类型
private boolean joinsACM; //是否参加过ACM比赛
创建一集合对象,如List,内有若干Student对象用于后面的测试。

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

关键代码:

ArrayList
list =new ArrayList
();for(Student a:s){ if(a.getId()>10&&a.getName().equals("zhang")&&a.getAge()>20&&a.getGender().equals(Gender.female)&&a.isJoinsACM()){ list.add(a); }

结果为

[Student{id=11, name='zhang', age=21, gender=female, joinsAcm=true}][Student{id=12, name='zhang', age=25, gender=female, joinsAcm=true}]

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

关键代码

ArrayList
arrayList2 = (ArrayList
) arrayList.parallelStream() .filter(student -> (student.getId() > 10L && student.getName().equals("zhang") && student.getAge() > 20 && student.getGender().equals(Gender.female) && student.isJoinsACM())) .collect(Collectors.toList());

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

List
result=student.stream().filter(stu-> stu!=null&&stu.getId() > 10L && stu.getName().equals("zhang") && stu.getAge() > 20 && stu.getGender().equals(Gender.FEMALE) && stu.isJoinsAcm()) .collect(Collectors.toList());

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

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

1109865-20170415203250658-1937030749.png

5.2 GeneralStack接口的代码

interface GeneralStack
{ E push(E item); E pop(); E peek(); public boolean empty(); public int size();}

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

泛型将操作的数据类型进行了参数化,使之和一个参数一样可变动,这道题中所编写的GeneralStack接口对于任何引用类型都适用,我们可以根据实际定义所需的数据类型,使得编写的代码可以被不同类型的对象所使用。如输入为"Integer"时,就将T替换为Integer,而无需定义多个接口

Q6 基础参考文件GenericMain,在此文件上进行修改。

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

public static void main(String[] args) {List
list1 = new ArrayList
();list1.add("abc");list1.add("cba");list1.add("acb");String min=Collections.max(list1);System.out.println(min);}public static
> T min(Collection
coll){ return Collections.max(coll);}

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

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

3.1. 码云代码提交记录

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

1109865-20170415204906970-624664426.png

3.2. PTA实验

函数(4-1),编程(5-3,5-4,5-5)

实验总结已经在作业中体现,不用写。

转载于:https://www.cnblogs.com/YYYYYYY/p/6715543.html

你可能感兴趣的文章
面向对象
查看>>
lintcode83- Single Number II- midium
查看>>
移动端 响应式、自适应、适配 实现方法分析(和其他基础知识拓展)
查看>>
selenium-窗口切换
查看>>
使用vue的v-model自定义 checkbox组件
查看>>
[工具] Sublime Text 使用指南
查看>>
Hangfire在ASP.NET CORE中的简单实现方法
查看>>
Algorithm——何为算法?
查看>>
Web服务器的原理
查看>>
小强升职计读书笔记
查看>>
常用的107条Javascript
查看>>
#10015 灯泡(无向图连通性+二分)
查看>>
elasticsearch 集群
查看>>
忘记root密码,怎么办
查看>>
linux设备驱动归纳总结(三):1.字符型设备之设备申请【转】
查看>>
《黑客与画家》 读书笔记
查看>>
bzoj4407: 于神之怒加强版
查看>>
mysql统计一张表中条目个数的方法
查看>>
ArcGIS多面体(multipatch)解析——引
查看>>
css3渐变画斜线 demo
查看>>