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

1. 本周学习总结

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

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

简单泛型定义:
public class Pair<T> {public Pair(T first, T second) {this.first = first;  this.second = second; }public T getFirst() { return first; }public void setFirst(T newValue) { first = newValue; }private T first; private T second;....
}

2. 书面作业

本次作业题集集合

Q1:List中指定元素的删除(题目4-1)
1.1 实验总结

答:这题比较简单,题目已经写好了Main函数,只需要我们写两个函数convertStringToList()和remove(),但是要注意的是要定义List<String> list = new ArrayList<String>(),在写remove()函数时,利用equals方法remove list元素。还有在eclipse中不小心定义包名为Java导致一直编译错误,所以浪费了一点时间在找错误,以后这种类型的错误是会注意了。

截图:
1109722-20170414224841205-742629405.png
1109722-20170414224848048-1637175597.png

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

Map<String,Integer> m = new HashMap<String,Integer>();//新建个Map映射while(in.hasNext()){String s = in.next();if (s.equals("!!!!!"))break;if(m.get(s) == null)m.put(s, 1);else m.put(s, m.get(s)+ 1);}//调用equals方法如果不输入!!!!!的情况下,则执行下面的语句。如果取s为相应的位置空则将单词放入s的这个位置上,否则放入s下一个位置。List<Entry<String,Integer>> list = new ArrayList<Entry<String,Integer>>(m.entrySet());//类型强制转换,把ArrayList<Entry<String,Integer>>(m.entrySet())强制转换为List<Entry<String,Integer>>类型,然后调用其Collection.sort方法比较单词出现的次数Collections.sort(list, new Comparator<Map.Entry<String, Integer>>() {@Overridepublic int compare(Map.Entry<String, Integer> o1,Map.Entry<String, Integer> o2) {if (o2.getValue() != o1.getValue())return o2.getValue() - o1.getValue();   elsereturn o1.getKey().compareTo(o2.getKey());  }});

2.2 实验总结

总结:这题先建立一个映射表,在while()循环里面调用equals方法确定是否输入单词结束,然后题目要求排序输出单词出现次数前十的单词,这时候就得把ArrayList<Entry<String,Integer>>(m.entrySet())强制转换为List<Entry<String,Integer>>类型,因为在Map映射里面没有排序的方法,然后调用Collections.sort()和Comparator方法得出单词出现次数前十的单词。这题需要注意的是Map接口不能实现排序。

Q3:倒排索引(题目5-4)
3.1 截图你的提交结果(出现学号)
1109722-20170415173730798-1111919651.png

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

//先建立两个键值对
TreeMap<String, TreeSet<Integer>> map = new TreeMap<String, TreeSet<Integer>>();
TreeMap<Integer, String> map2 = new TreeMap<Integer, String>();//第一个大的while循环建立索引然后并输出。
while (sc.hasNextLine()) 
{String s=sc.nextLine();if (s.equals("!!!!!")) {break;} else {Scanner in = new Scanner(s);map2.put(row, s);while (in.hasNext()) {if (map.get(s1) == null) {TreeSet<Integer> set = new TreeSet<Integer>();set.add(row);map.put(s1, set);} else {map.get(s1).add(row);}}}row++;}//这个while循环倒排索引查询的问题,如果没有找到直接输出found 0 results。
while (sc.hasNextLine()) {String s2 = sc.nextLine();if (s2.length() == 0) {System.out.println("found 0 results");continue;}else{....}

3.3 实验总结

总结:这道题我构思了挺久也没有写完整,最后参考了写出来的同学的代码才完成了,觉得难度还是有点。用到了Map接口的一些add()和put()方法,要注意的是单词找不到的情况,只要有一个单词找不到,返回空集即可,还有建立两个键值对为TreeMap<String, TreeSet<Integer>> map = new TreeMap<String, TreeSet<Integer>>();TreeMap<Integer, String> map2 = new TreeMap<Integer, String>(),然后按顺序先解决输入若干行英文还有索引,然后在解决倒排索引 查询结果。

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

 @Overridepublic String toString() {return "Student [id=" + id + ", name=" + name + ", age=" + age + ", gender=" + gender + ", joinsACM=" + joinsACM+ "]";}public Student(Long id, String name, int age, Gender gender, boolean joinsACM) {super();this.id = id;this.name = name;this.age = age;this.gender = gender;this.joinsACM = joinsACM;}public Student chioce(){if(this.id>10L&&this.name.equals("zhang")&&this.age>20&&this.gender.equals(Gender.女)&&this.joinsACM){Student List=new Student(this.id,this.name,this.age,this.gender,this.joinsACM);return  List;}return null;}

1109722-20170415132346611-728138056.png
1109722-20170415132357376-1152298894.png

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

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

Q5:泛型类:GeneralStack(题目5-5)
5.1 截图你的提交结果(出现学号)
1109722-20170414211857798-2036188504.png

5.2 GeneralStack接口的代码

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

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

泛型的好处是:消除强制类型转换,消除源代码中的许多强制类型转换,这使得代码更加可读,并且减少了出错机会;类型安全。 泛型的主要目标是提高 Java 程序的类型安全。通过知道使用泛型定义的变量的类型限制,编译器可以在一个高得多的程度上验证类型假设。没有泛型,这些假设就只存在于程序员的头脑中

Q6:泛型方法 基础参考文件GenericMain,在此文件上进行修改。
6.1 编写方法max,该方法可以返回List中所有元素的最大值。List中的元素必须实现Comparable接口。编写的max方法需使得String max = max(strList)可以运行成功,其中strList为List类型。也能使得Integer maxInt = max(intList);运行成功,其中intList为List类型。
6.2 选做:现有User类,其子类为StuUser,且均实现了Comparable接口。编写方法max1,基本功能同6.1,并使得max1(stuList);可以运行成功,其中stuList为List类型。
6.3 选做:编写int myCompare(T o1, T o2, Comparator c)方法,该方法可以比较User对象及其子对象,传入的比较器c既可以是Comparator,也可以是Comparator。注意:该方法声明未写全,请自行补全。

Q7:选做:逆向最大匹配分词算法
集合实验文件中的第07次实验(集合).doc文件,里面的题目6.
7.1 写出伪代码
7.2 实验总结

Q8:选做:JavaFX入门
完成其中的作业1、作业2。内有代码,可在其上进行适当的改造。建议按照里面的教程,从头到尾自己搭建。

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

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

3.1. 码云代码提交记录

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

1109722-20170415173630001-1427333974.png

3.2. PTA实验

函数(4-1),编程(5-3,5-4,5-5)
验总结已经在作业中体现,不用写。

转载于:https://www.cnblogs.com/wen1234/p/6710072.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/488578.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

mysql driver 读写分离_Mysql主从复制和读写分离实践

1、主从复制原理MySQL之间数据复制的基础是二进制日志文件(binary log file)。一台MySQL数据库一旦启用二进制日志后&#xff0c;其作为master&#xff0c;它的数据库中所有操作都会以“事件”的方式记录在二进制日志中&#xff0c;其他数据库作为slave通过一个I/O线程与主服务…

二十世纪最伟大的10大算法

来源&#xff1a;数学中国发明十大算法的其中几位算法大师1、1946 蒙特卡洛方法[1946: John von Neumann, StanUlam, and Nick Metropolis, all at the Los Alamos Scientific Laboratory, cook upthe Metropolis algorithm, also known as the Monte Carlo method.]1946年&…

mybatis 动态字段与表中不一样_8.mybatis的基本工作流程(2.0)※

mybatis的基本工作流程1.读取配置文件&#xff0c;配置文件包含数据库连接信息和Mapper映射文件或者Mapper包路径。2.有了这些信息就能创建SqlSessionFactory&#xff0c;SqlSessionFactory的生命周期是程序级,程序运行的时候建立起来,程序结束的时候消亡3.SqlSessionFactory建…

题目填坑计划

一个蒟蒻的最后的挣扎 吉林 JLOI 2016 侦察守卫 树形DP 可怕的题目&#xff0c;照题解抄了一遍&#xff0c;和它相似的题目还有HDU5290BombingPlan 方 容斥乱搞 可怕的题目&#xff0c;看题解懂的&#xff0c;但是完全写不来 成绩比较 组合DP 找题解理解了并且做完了&#xff0…

判断表达式值是否为空_如何在 Python 中判断列表是否为空

在判断列表是否为空时&#xff0c;你更喜欢哪种方式&#xff1f;决定因素是什么&#xff1f;在 Python 中有很多检查列表是否是空的方式&#xff0c;在讨论解决方案前&#xff0c;先说一下不同方法涉及到的不同因素。我们可以把判断表达式可以分为两个阵营&#xff1a;对空列表…

HDU 5890 Eighty seven(DP+bitset优化)

题目链接 Eighty seven 背包&#xff08;用bitset预处理&#xff09;然后对于每个询问O&#xff08;1&#xff09;回答即可。 预处理的时候背包。 #include <bits/stdc.h>using namespace std;#define rep(i, a, b) for(int i(a); i < (b); i) #define dec(i, …

《Lancet》发表全球学者联合声明!

来源&#xff1a;中国生物技术网 2020年2月18日&#xff0c;《LANCET》上发表通讯&#xff08;Correspondence&#xff09;文章&#xff0c;全球科学家发表声明反对阴谋论&#xff0c;全力支持奋战在疫情一线的中国科研技术工作者。就像病毒没有国界一样&#xff0c;科学也没有…

python时间序列库_时间序列数据处理python 库

【注】本人原创&#xff0c;最初发表于CSDN&#xff0c;后发布于知乎。为避免误会为抄袭&#xff0c;特此说明 由于我热衷于机器学习在时间序列中的应用&#xff0c;特别是在医学检测和分类中&#xff0c;在尝试的过程中&#xff0c;一直在寻找优质的Python库&#xff08;而不是…

python代数式的表达方式_关于python字典类型最疯狂的表达方式

一个Python字典表达式谜题让我们探究一下下面这个晦涩的python字典表达式&#xff0c;以找出在python解释器的中未知的内部到底发生了什么。# 一个python谜题&#xff1a;这是一个秘密# 这个表达式计算以后会得到什么结果&#xff1f;>>>{True: yes, 1: no, 1.0: mayb…

【LeetCode】152. Maximum Product Subarray

题目&#xff1a;   Find the contiguous subarray within an array (containing at least one number) which has the largest product. For example, given the array [2,3,-2,4],the contiguous subarray [2,3] has the largest product 6. 题解&#xff1a; 先暴力解&am…

“哥德尔不完备定理”到底说了些什么?

来源&#xff1a; 赵昊彤科学网博客链接地址&#xff1a;http://blog.sciencenet.cn/blog-409681-1067019.html 【编者按&#xff1a;不知为何&#xff1f;一直不相信已有的数理、物理、生理、心理、管理……能够研究好人机融合智能系统。究其因&#xff0c;需要出现新的数/物…

ghost镜像浏览器_新电脑,GHOST装不进系统?不要急,跟我来

前几天&#xff0c;朋友转了台新电脑&#xff0c;用的是第十代CPU I3 10100&#xff0c;什么都安装好了&#xff0c;也按要求做了GPT分区&#xff0c;用GHOST安装了WIN10系统&#xff0c;可是重启时就是进不去&#xff0c;在BOOT选项里根本看不到硬盘。这是为什么呢&#xff1f…

如何卸载mysql server 2005_如何卸载SQL Server 2005

卸载SQL Server 2005的方法之一&#xff0c;放在这儿只是为了记住&#xff1a;1&#xff1a;把SQL Server2005的安装盘(安装文件)放入到光驱。2&#xff1a;打开如下路径&#xff1a;开始/运行&#xff0c;输入&#xff1a;cmd3&#xff1a;输入下列命令&#xff1a;Start /wai…

python异步消费kafka_Kafka 通过python简单的生产消费实现

使用CentOS6.5、python3.6、kafkaScala 2.10 - kafka_2.10-0.8.2.2.tgz (asc, md5) 一、下载kafka 下载地址 https://kafka.apache.org/downloads 里面包含zookeeper二、安装Kafka 1、安装zookeeper mkdir /root/kafka/ tar -vzxf kafka_2.10-0.8.2.2cd /root/kafka/kafka_2.10…

【技术趋势】2020 五大技术趋势:无人驾驶发展、机器视觉崛起、区块链实用化、人类增强技术、超自动化...

图源&#xff1a;https://unsplash.com/来源&#xff1a;AI开发者原标题&#xff1a;Here Is A Rundown of 5 Major Tech Trends Hitting 2020作者&#xff1a;| Richard Liu链接&#xff1a;https://medium.com/swlh/here-is-a-rundown-of-5-major-tech-trends-hitting-2020-6…

正则不能输入特殊字符_正则表达式语法学习和在线练习

标题: 正则表达式语法学习和在线练习作者: 梦幻之心星 sky-seekerqq.com标签: [#正则表达式,#语法,#学习,#练习]目录: [语法]日期: 2021-01-26背景说明正则表达式使搜索和替换操作更加灵活高效。许多程序设计语言都支持使用正则表达式进行字符串操作。正则表达式是由普通字符…

JavaScript Math 对象

// 返回算术常量 e&#xff0c;即自然对数的底数&#xff08;约等于2.718&#xff09;。 Math.E; // 2.718281828459045 // 返回圆周率&#xff08;约等于3.14159&#xff09;。 Math.PI; // 3.141592653589793 // 返回最低值。 Math.min(1, 2, 3, 4, 5, 6); // 1 // 返回最高值…

非接触物体尺寸形态测量_检修人必备的测量常识

小编今天给大家分享一下测量的常识&#xff0c;咱们搞机械的一定要懂点测量知识&#xff01;一、测量器具的分类测量器具是一种具有固定形态、用以复现或提供一个或多个已知量值的器具。按用途的不同量具可分为以下几类&#xff1a;1. 单值量具只能体现一个单一量值的量具。可用…

生物战教训、生物安全问题以及未来监控军民两用生物技术扩散的手段

来源&#xff1a;美国空军国家安全研究学会研究报告2005年9月【知远导读】本篇推送编辑节选自美国空军国家安全研究学会2005年9月发布的一份题为《生物战教训、生物安全问题以及未来监控军民两用生物技术扩散的手段》的研究报告。该报告直接来源于作者海伦普凯特&#xff08;He…

python关系运算符和逻辑运算符的优先级_python中逻辑运算符的优先级问题

遇到的问题今天做题的时候&#xff0c;碰到一个关于逻辑运算符优先级的问题&#xff0c;看到之后我懵了0 and 12 and 30 or 12 or 3上面的返回值是什么&#xff1f;我一开始以为返回的都是左边的值&#xff0c;但是结果和我想的不同&#xff0c;结果如下&#xff1a;In [4]: 0 …