第7周作业-集合


1.本周学习总结

2.书面作业

1.List中指定元素的删除

题集jmu-Java-05-集合之4-1

1.1 实验总结


  这次的函数题是编写convertStringToListremove函数。我首先写的是convertStringToList,一开始我是将line调用String类的split方法(line.split(" "))存入一个String类型的数组中,然后使用asList返回这个数组。这样实现,前面的样例输入都解决了,但是最后一个字符串1 2 3 4 1 3 1的1和2之间有两个空格就无法去掉。后来查阅帮助文档,发现split方法使用的正则表达式中有一个数量词上的用法:

  

  其中,X+表示一次或多次,所以,我将line.split(" ")改为了line.split(" +"),这样即使是出现单个字符之间出现多个空格的问题也就解决了。

  remove函数的编写上遇到的麻烦就比较多了,从理解函数的两个入参开始我就出现了偏差,以为是list要与str中的每一个字符比较,结果就走歪了,知道看懂了样例输入才明白。在删除重复元素的问题上,发现使用list.remove会抛java.lang.UnsupportedOperationException异常。查找了一下Java编程思想明白了问题所在:原因出在上一个函数convertStringToList中的asList上,这是没有办法使用list.remove的。所以我将asList改成了将其存入ArrayList,顺利进行删除之后问题又出现了,

if (list.get(i).equals(str)) {
list.remove(i);

  这样写会出现有一部分指定字符没有删掉的情况,通过设置断点调试的方式发现,当删除字符后,后面的字符全部前移,这个时候for循环自增后移就会出现跳过字符的情况,所以只能通过再将自增的ii--回来,来达到我们遍历整个list的目的。

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

2.统计文字中的单词数量并按出现次数排序(尽量不要出现代码)

题集jmu-Java-05-集合之5-3 统计文字中的单词数量并按出现次数排序

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

  read 每一个单词建立map映射;
  if(如果单词重复出现)
    则修改键值+1;
  else
    键值为1;

2.2 实验总结

    这题就个人来说还是挺难的,因为对老师上课讲的map这块理解的不是太好,做起来还是磕磕绊绊,乍一看到题目有点无从下手,看了好久才看到按照键值,才明白要用map做。出问题最大的地方在于最后输出出现次数排名前10的单词及出现次数这个地方,

        for (int i = 0; i < 10; i++) {
System.out.println(list.get(i));
}

报错无数次,list从0开始就越界了,最终无语地发现是自己new出list的时候就没有往里面放东西,list就是空的,使用map.entrySet()方法将map包装成集合在对其排序就没有问题了。

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

3.倒排索引(尽量不要出现代码)

题集jmu-Java-05-集合之5-4

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

  create a map;
  read all words in line;
    create a set and add the line number and nonredundant words into the set;
    ergodic(遍历) all words to search keywords;
      if(the search result isEmpty)
       print(found 0 results);
      else
        print(the set);

3.2 实验总结

  这道题我觉得是这次实验中最难的一道题了,一开始知道一定要用到TreeMap,可是完全不知从何处下手,只好寻求嘉廉学霸的指导。尽管有了学霸的点拨,但是还是很困难,不过最后还是做出来了。在做题的过程中,我遇到了一个以前没有出现过的异常: java.util.NoSuchElementException,出现这个异常的原因是没有考虑到输入的查询关键字的长度为0的情况。这题实验暴露出来的最大的问题就是自己对集合这一块特别不熟悉,使用起来不熟练。

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的函数,并测试。

输出结果:

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



  添加了null之后,如果不加以判断的话就会报java.lang.NullPointerException空指针异常。但是加判断必须要在后面这些判断条件之前,否则就会先判断是否符合条件,依旧会抛空指针异常,相当于这句判断不为空就没有用了。所以必须在一开始就判断。

5.泛型类:GeneralStack

题集jmu-Java-05-集合之5-5 GeneralStack

5.1 GeneralStack接口的代码

interface GeneralStack<E> {
public E push(E item); // 如item为null,则不入栈直接返回null。 public E pop(); // 出栈,如为空,则返回null. public E peek(); // 获得栈顶元素,如为空,则返回null. public boolean empty();// 如为空返回true public int size(); // 返回栈中元素数量
}

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

  使用泛型定义接口,使得我们在编译程序的时候方法不再局限于某一个基本类型。本题的stack需要实现Interger、DoubleCar三种类型,如果我们没有学过泛型,那我们就只能每一种都去实现一个仅仅是数据类型不同但方法完全相同的GeneralStack接口。因此使用了泛型可以大大减少代码的冗余,大幅精简代码。

  

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

6.泛型方法

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

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

public class GenericMain {

	public static void main(String[] args) {
List<String> strList = new ArrayList<String>();
List<Integer> intList = new ArrayList<Integer>();
strList.add("h");
strList.add("b");
strList.add("e");
intList.add(24);
intList.add(5);
intList.add(81);
String max = max(strList);
Integer maxInt = max(intList);
System.out.println("max = " + max);
System.out.println("maxInt =" + maxInt);
} public static <T extends Comparable<T>> T max(List<T> list) {
T max = list.get(0);
for(T i : list){
if(i.compareTo(max)>0)
max = i;
}
return max;
}
}

输出结果:

6.2 编写方法max1,基本功能同6.1,但让其所返回的值可以赋予其父类型变量。如有User类,其子类为StuUser,且均实现了Comparable接口。编写max1使得User user = max1(stuList);可以运行成功,其中stuList为List类型。也可使得Object user = max(stuList)运行成功。

public class GenericMain {

	public static void main(String[] args) {
List<StuUser> stuList = new ArrayList<StuUser>();
stuList.add(new StuUser(21, "107"));
stuList.add(new StuUser(20, "91"));
stuList.add(new StuUser(21, "84"));
System.out.println(max1(stuList));
} public static <stuCompare extends Comparable<StuUser>> StuUser max1(List<StuUser> stuList) {
StuUser max1 = stuList.get(0);
for(StuUser stu : stuList){
if(stu.compareTo(max1)>0)
max1 = stu;
}
return max1;
}
}

输出结果:

6.3 选做:编写int myCompare(T o1, T o2, Comparator c)方法,该方法可以比较User对象及其子对象,传入的比较器c既可以是Comparator,也可以是Comparator。注意:该方法声明未写全,请自行补全。

public class GenericMain {

	public static void main(String[] args) {
// List<StuUser> stuList = new ArrayList<StuUser>();
// stuList.add(new StuUser(21, "107"));
// stuList.add(new StuUser(20, "91"));
// stuList.add(new StuUser(21, "84"));
UserReverseComparator userReverseComparator = new UserReverseComparator();
StuUserComparator stuUserComparator = new StuUserComparator();
User user = new User(22);
StuUser stuUser = new StuUser(21, "107");
StuUser stuUser1 = new StuUser(20, "91");
System.out.println(user);
System.out.println(stuUser);
System.out.println(stuUser1);
System.out.println(myCompare(stuUser, stuUser1, userReverseComparator));
System.out.println(myCompare(stuUser, stuUser1, stuUserComparator));
} public static <T> int myCompare(T o1, T o2, Comparator c) {
int result = c.compare(o1, o2);
return result;
}
}

输出结果:

PS:一开始得到这个结果的时候,-8这个值是怎么得到的让我有点不太明白,所以去查了一下JDK帮助文档中对于compareTo方法的解释才明白,它是将107和91中每个字符拿出来比较,所以是先比较107的第一个字符和91的第一个字符9,答案就是-8了;如果将107改成97,这样一来两个字符串的第一个字符就相等了,那么就会比较第二个字符7和1,答案也就呼之欲出了—— 6。

3.使用码云管理Java代码

本周Commit历史截图

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

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

3.1. 码云代码提交记录

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


3.2. PTA实验

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

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

201521123107 《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. 【社交系统研发日记五】ThinkSNS+如何计算字符显示长度?

    今天我们来聊一下可能很多人都会头疼的东西:显示长度. 需求是这样的,在字符的显示上,两个英文单词才占一个中文或者其他语言的显示长度.如下: 上面排的是两个英文字母,一个汉字,一个Emoji.你会发现, ...

  2. Python集合(set)类型的操作

    python的set和其他语言类似, 是一个无序不重复元素集, 基本功能包括关系测试和消除重复元素. 集合对象还支持union(联合), intersection(交), difference(差)和 ...

  3. 关于CGI:Tomcat、PHP、Perl、Python和FastCGI之间的关系

    如前文所述,Web服务器是一个很简单的东西,并不负责动态网页的构建,只能转发静态网页.同时Apache也说,他能支持perl,生成动态网页.这个支持perl,其实是apache越位了,做了一件额外的事 ...

  4. SQL查询操作及子句优先级

    用source .sql文件竟然可以自动建表. 简单数据查询: select * from table_name; 避免重复查询: select distinct(field_name) from t ...

  5. CentOS 7 服务器配置--配置Tomcat开机启动

    #编辑Tomcat的文件,追加内容 vi /data/tomcat/apache-tomcat-8.0.43/bin/catalina.sh #追加内容,在CLASSPATH= 上面的第三行 CATA ...

  6. S7-300之间的PROFIBUS-DP主从通信

    一.PROFIBUS-DP简介 1.由来 2..总线连接器 二.系统结构示例 三.组态过程示例 三,DP网络组态 1.新建一个项目和两个300站点如下 2.组态从站DP网络 1)点击常规中的属性 2) ...

  7. Java连接数据库的4中方式详解

    Java连接数据库的方式有多种:根据所需要的不同数据库驱动分,分为四种: 1:1类驱动.这就是JDBC-ODBC桥的方式. 但这种方式不适合程序的重用与维护,不推荐使用.需要数据库的ODBC驱动. 2 ...

  8. MarkdownPad2之安装破解

    MarkdownPad2之安装破解 一.下载破解版 1.地址链接:http://pan.baidu.com/s/1i5JzG13 密码: 4jgw 2.按步骤安装后,进行汉化:[Tool]--> ...

  9. python自动化运维五:pexpect

    p { margin-bottom: 0.25cm; line-height: 120% } a:link { } pexpect是expect的封装,可以实现ssh,ftp,passwd,telne ...

  10. 【秒懂】号称最为简明实用的Django上手教程

    号称最为简明实用的Django上手教程 作者:白宁超 2017年8月24日09:37:35 摘要:Django的学习教程也是分门别类,形式不一.或是较为体系的官方文档,或者风格自由的博客文档,或者偏向 ...