1.1 以你喜欢的方式(思惟导图或其余)概括总结集合与泛型相关内容。
java
1.2 选作:收集你认为有用的代码片断数组
本次做业题集集合网络
1. List中指定元素的删除(题集题目)
1.1 实验总结。并回答:列举至少2种在List中删除元素的方法。
这道题中,当空格数量不一样时,用String[] str==line.split(" +")分开。
可用remove()方法删除元素学习
public static void remove(List<String> list, String word) { for (int i = list.size()-1;i>=0; i--) { if(word.equals(list.get(i))){ list.remove(i); } } } //迭代器删除 public static void remove(List<String> list, String word) { for (Iterator<String> iterator = list.iterator(); iterator.hasNext();) { String str = (String) iterator.next(); if (str.equals(word)) iterator.remove(); } }
2. 统计文字中的单词数量并按出现次数排序(题集题目)测试
2.1 伪代码(不得复制代码,不然扣分)设计
建立HashMap对象map; 读入字符串; 当遇到!!!!!时退出; 当map中不存在word时times=1; 当map中存在word时times+1; 建立ArrayList对象list; 用Collections.sort()排序; 输出map长度; 输出前十个数据;
2.2 实验总结code
List<Map.Entry<String,Integer>> list=new ArrayList<Map.Entry<String,Integer>>(map.entrySet()); Collections.sort(list,new Comparator<Map.Entry<String,Integer>>(){ public int compare(Map.Entry<String,Integer>o1,Map.Entry<String,Integer>o2) { if(o1.getValue()==o2.getValue()){ return o1.getKey().compareTo(o2.getKey()); } if( o1.getValue()>o2.getValue()) return -1; else return 1; } });
这道题是主要把Map中的键值对放进ArrayList,而后用Collections.sort()排序。
3. 倒排索引(题集题目)对象
本题较难,作不出来没关系。但必定要有本身的思考过程,要有提交结果。
3.1 截图你的代码运行结果
3.2 伪代码(不得复制代码,不然扣分)blog
建立TreeMap; 当不为!!!!!时输入行数,当为!!!!!时break; 将输入的用split分开放到数组; 当map里面包含Word时,获得这个Word的行数,并把这个行数加入到list; 输入put(字符,有包含字符的行数); 而后输出map;
3.3 实验总结排序
这道题还没作出来,思路是把单词对应的行数放到list中,而后输出,但尚未作出来,因此没有运行截图。
4.Stream与Lambda
编写一个Student类,属性为: private Long id; private String name; private int age; private Gender gender;//枚举类型 private boolean joinsACM; //是否参加过ACM比赛
建立一集合对象,如List
4.1 使用传统方法编写一个搜索方法List
public static void main(String[] args) { List<Student> stu = new ArrayList<Student>(); stu.add(new Student((long) 58,"xiao",15,Gender.man,false)); stu.add( new Student((long) 54,"an",16,Gender.woman,true)); stu.add( new Student((long) 100,"an",17,Gender.man,true)); stu.add ( new Student((long) 82,"zhang",18,Gender.woman,true)); stu.add( new Student((long) 90,"zhang",19,Gender.woman,true)); List<Student> stu1 = search((long) 80, "zhang",18,Gender.woman, true,stu) System.out.println("网络1611张凯艳"); for (Student student : stu1) { System.out.println(student); } } public static List<Student> search(Long id, String name, int age, Gender gender, boolean joinsACM,List<Student> list){ List<Student> stu = new ArrayList<Student>(); for(Student e:list){ if(e.getId()>id&&e.getName().equals(name)&&e.getGender()==gender&&e.isJoinsACM()==joinsACM){ stu.add(e); } } return stu; }
4.2 使用java8中的stream(), filter(), collect()编写功能同4.1的代码,并测试(要出现测试数据)。构建测试集合的时候,除了正常的Student对象,再往集合中添加一些null,你编写的方法应该能处理这些null而不是抛出异常。(截图:出现学号)
List<Student> stu1 = stu.stream().filter(e -> e!=null&&e.getId()>80&&e.getName().equals("zhang")&&e.getAge()>=18&&e.getGender()==Gender.woman&&e.isJoinsACM()==true).collect(Collectors.toList());
5. 泛型类:GeneralStack
5.1 GeneralStack接口的代码
interface GeneralStack<T>{ public T push(T item); public T pop(); public T peek(); public boolean empty(); public int size(); }
5.2 结合本题与之前做业中的ArrayListIntegerStack相比,说明泛型有什么好处
在之前做业中的ArrayListIntegerStack
中若是已经肯定了栈中元素的类型,那么元素类型就是肯定不能改变的,而若是用泛型时能够选择改变元素的类型,比较灵活。
3.1. 码云代码提交记录
3.2 截图PTA题集完成状况图
3.3 统计本周完成的代码量
周次 | 总代码量 | 新增代码量 | 总文件数 | 新增文件数 |
---|---|---|---|---|
2 | 381 | 381 | 12 | 5 |
3 | 661 | 280 | 19 | 7 |
4 | 974 | 313 | 24 | 5 |
5 | 1358 | 384 | 33 | 9 |
6 | 2211 | 853 | 37 | 4 |
7 | 3223 | 412 | 42 | 5 |
8 | 3635 | 423 | 46 | 4 |
4. 评估本身对Java的理解程度
尝试从如下几个维度评估本身对Java的理解程度
维度 | 程度 |
---|---|
语法 | PTA的题目只能作出一小部分,语法还不是很熟练 |
面向对象设计能力 | 还比较差 |
应用能力 | |
至今为止代码行数 | 3635 |