①foreach循环java
for (String e : map.keySet()) { System.out.println(e+"="+map.get(a)); }
②迭代器编程
Set<String> set=map.keySet(); Iterator<String> it=set.iterator(); while(it.hasNext()){ String a=it.next(); System.out.println(a+"="+map.get(a)); }
实验总结:
这道题中,我学习到,Scanner不只能够从控制台System.in
中读取,也能够从字符串String
中读取,使用这种方式,能够自动以空格为分隔符,对单词进行划分,对比split
要方便得多,且输出不容易出错。具体语法是:学习
Scanner sc= new Scanner(line); while(sc.hasNext()){ list.add(sc.next()); }
此题还遇到一个粗心的小问题,就是使用equals
和指定对象str
进行对比时,给str
加上了引号。修改后提交正确。测试
List中删除元素的方法
方法一:须要注意的是,这个方法要从下标倒序开始删除,避免删除后下表修改致使跳过元素。设计
for (int i=list.size()-1;i>=0;i--) { if((list.get(i)).equals(str)){ list.remove(i); } }
方法二:使用迭代器删除元素3d
for(Iterator<Integer> iterator = list.iterator();iterator.hasNext(); ){ int e = iterator.next(); if(e%2==0) iterator.remove(); }
新建HsahMap对象为map while(1){ if(输入为“!!!!”) break; else if(map中已有元素) 将(key元素,value+1)传入map else (key,value=1)传入map } 建立ArrayList对象list 实现Collections接口对map对象进行排序 输出map的长度 输出排序后list中前十个数据
此题的关键是运用的hashmap,其中key存放单词,value存放单词出现的次数。在将数据都输入map后,如何排序成为个人拦路石。在老师的指点下,知道了须要经过ArrayList来存放map数据,并接入Collections接口实现排序。、
感想:
此题若让我独立完成会很是困难,问题在于我没法很快地将ArrayLIst的知识u也能用到此题中。这提醒我,要增强综合编程能力,不能只是简单地完成每一章节的学习,而要不时地将各章节内容结合起来进行变成。code
新建Map对象map,key为String,value为ArrayList 建立ArrayList对象line while(true){ if (遇到("!!!!!")) { break; } else { if(map中没有相应的key) 把单词添加到map中,同时将当前行数的值添加到value中 else 判断是否已经存在于value中,若没有,则添加当前行数到value中 } 建立迭代器,遍历输出,且以空格分隔 }
答:此题未能独立完成,仅完成存放并输出map。对于倒排索引,阅读同窗的代码稍微有一点头绪。不能理解的地方是,value的类型为ArrayList,同窗解释说方便存储单词出现的行数。除了不能理解如何实现倒排索引,我还考虑过一行出现多个相同单词的状况,以及一些其余的状况,但最初的输出行数都未能实现,这些思考也就一样没有实现。对象
编写一个Student类,属性为:blog
private Long id; private String name; private int age; private Gender gender;//枚举类型 private boolean joinsACM; //是否参加过ACM比赛
建立一集合对象,如List
List<Student> search(List<Student> stuList, Long id, String name, int age, Gender gender, boolean joinsACM)
,而后调用该方法将id>某个值,name为某个值, age>某个值, gender为某个值,参加过ACM比赛的学生筛选出来,放入新的集合。在main中调用,而后输出结果。(截图:出现学号、姓名)
List<Student> newStudent = s.stream().filter(e -> e!=null&&e.getId()>50L&&e.getName().equals("Gao")&&e.getAge()>18&&e.getGender()==Gender.male&&e.isJoinsACM()==true).collect(Collectors.toList());
public interface GeneralStack<E> { E push(E item); E pop(); E peek(); public boolean empty(); public int size(); }
答:使用ArrayListIntegerStack
定义完成后,只能够存放Integer类型。使用泛型,能够根据定义不一样,存放不一样类型的栈,包括本身定义的引用类型,使得栈的应用范围变广阔不少,显示了扩展性。
题目集:jmu-Java-05-集合
在码云的项目中,依次选择“统计-Commits历史-设置时间段”, 而后搜索并截图
须要有两张图(1. 排名图。2.PTA提交列表图)
为了截图完整的提交列表,把界面缩小了,老师能够放大网页界面查看。
须要将每周的代码统计状况融合到一张表中。
周次 | 总代码量 | 新增代码量 | 总文件数 | 新增文件数 |
---|---|---|---|---|
1 | 0 | 0 | 0 | 0 |
2 | 0 | 0 | 0 | 0 |
3 | 639 | 639 | 16 | 16 |
4 | 639 | 0 | 16 | 0 |
5 | 841 | 202 | 19 | 3 |
6 | 1075 | 234 | 23 | 4 |
7 | 1419 | 344 | 27 | 4 |
8 | 2028 | 609 | 33 | 6 |
9 | 2194 | 166 | 37 | 4 |
10 | 2625 | 431 | 41 | 4 |
本身的目标能实现吗?
这是学期初顶下的目标
就目前来看,虽然被各类工做缠身,但学习还算跟上了。半个学期过去,目前代码是2600行,距离目标6000行还有必定的距离。后续学生工做不那么多,只须要专一学习和科研立项,那么这一目标仍是能够实现的。
维度 | 程度 |
---|---|
语法 | PTA的题目大部分可以自主完成,即便要花费一点时间,但语法基础基本掌握 |
面向对象设计 | 可以自主设计对应的类,对对象的属性和方法可以符合需求 |
应用能力 | 较欠缺,尤为综合应用能力,剩下半个学期着重锻炼这一能力 |
至今为止代码行数 | 2625 |