第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. 利用GeoIP数据库及API进行地理定位查询 Java

    地理定位查询的的数据库比较多,而且大多都开放一些free的版本 国内的有纯真数据库等,但是他只提供文本的地理位置信息,不提供经纬度数据 当应用到google map时,就不可以了 国外的有MaxMin ...

  2. C语言程序设计进阶 翁恺 第4周编程练习

    第4周编程练习 查看帮助 返回 第4周编程练习 依照学术诚信条款,我保证此作业是本人独立完成的. 温馨提示: 1.本次作业属于Online Judge题目,提交后由系统即时判分. 2.学生可以在作业 ...

  3. 再起航,我的学习笔记之JavaScript设计模式09(原型模式)

    我的学习笔记是根据我的学习情况来定期更新的,预计2-3天更新一章,主要是给大家分享一下,我所学到的知识,如果有什么错误请在评论中指点出来,我一定虚心接受,那么废话不多说开始我们今天的学习分享吧! 我们 ...

  4. TCP/IP小记

    --TCP/IP小记 -----------------2014/06/11 TCP的要求是:local_ip:local_port <==>remote_ip:remote_port这个 ...

  5. Adaboost、RandomFrest、GBRT的区别

    Adaboost.RandomFrest.GBRT都是基于决策树的组合算法 Adaboost是通过迭代地学习每一个基分类器,每次迭代中,把上一次错分类的数据权值增大,正确分类的数据权值减小,然后将基分 ...

  6. 用github展示前端页面

    今天尝试了一下使用github展示前端页面,还是比较简单的,平时做一些小的demo时,可以用这个方法展示自己的页面,在此记录下方法. 首先打开自己的github项目仓库,比如   https://gi ...

  7. 200行的Node爬虫花了半天的时间把网易云上的30万首歌曲信息都抓取回来了

    早两天在网易云听歌看评论的时候,突然想把网易云上所有歌曲都抓取下来然后按照评论数进行一次排名,把评论数超过10万的歌曲都听一次,于是便有了这个项目. 因为只是一个小前端,所以使用了Node来写这个爬虫 ...

  8. 关于curl / curl_multi的一些实验

    几天没写了,主要都是自己的学习过程,贴一下curl / curl_multi_exec的一些代码,mark一下. <?php /** * Created by PhpStorm. * User: ...

  9. Zepto源码分析(一)核心代码分析

    本文只分析核心的部分代码,并且在这部分代码有删减,但是不影响代码的正常运行. 目录 * 用闭包封装Zepto * 开始处理细节 * 正式处理数据(获取选择器选择的DOM) * 正式处理数据(添加DOM ...

  10. 【Spring 核心】装配bean(二) JavaConfig装配

    前面介绍完了组件扫描和自动装配,这里再来看一下装配bean的另一种方式JavaConfig. 包路径: src/main/java com.bonc-|--config--|--CDPlayerCon ...