zoukankan      html  css  js  c++  java
  • 学号:201521123116 《java程序设计》第八周学习总结

    1. 本周学习总结

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

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

    List<Entry<String,Integer>> list = new ArrayList<Entry<String,Integer>>(map.entrySet());

    Scanner in = new Scanner(line);

    2. 书面作业

    1. List中指定元素的删除(题目4-1)

    1.1 实验总结:

    • 返回的数组元素类型是Object,调用者可以自由地修改iterator返回的数组。
    • 用列表来实现排序。
    • 扫描器可以用做遍历使用。

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

    2.统计文字中的单词数量并按出现次数排序

    Scanner input=new Scanner(System.in);
    Map<String,Integer>map=new HashMap<String ,Integer>();
    String x;
    while(true){
    x=input.next();
    if(x.equals("!!!!!"))break;

    if(map.containsKey(x)) map.put(x, map.get(x)+1);
    if(map.get(x)==null) map.put(x, 1);
    }
    System.out.println(map.size());
    List<Entry<String,Integer>> list =new ArrayList<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 o2.getValue() - o1.getValue();
    }
    else {
    return o1.getKey().compareTo(o2.getKey());
    }
    }
    });

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

    2.2 实验总结

    TreeSet类实现Set接口,不含重复对象.将map对象转变为list对象,用entrySet()同时取得map的键和值

    3. 倒排索引(题目5-4)

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

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


    int row = 1;
    while (scan.hasNextLine()) {
    String s = scan.nextLine();
    if (s.equals("!!!!!")) {
    break;
    }
    else {
    Scanner scan1 = new Scanner(s);
    map2.put(row, s);
    while (scan1.hasNext()) {
    String s1 = scan1.next();
    if (map.get(s1) == null) {
    TreeSet<Integer> set = new TreeSet<Integer>();
    set.add(row);
    map.put(s1, set);
    }
    else {
    map.get(s1).add(row);
    }
    }
    scan1.close();
    }
    row++;
    }
    for (Map.Entry<String, TreeSet<Integer>> a : map.entrySet()) {
    System.out.println(a);
    }

    if (!map.containsKey(s)) {
    System.out.println("found 0 results");
    continue;
    }
    TreeSet<Integer> set1 = map.get(s);
    while (scan1.hasNext()) {
    String s1 = scan1.next();
    set1.retainAll(map.get(s1));

    3.3 实验总结

    对于Map的运用还不熟练,这道题目还是在同学帮助下完成的。

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

    ArrayList<Student> aList = new ArrayList<Student>();

    for (Student student : arrayList) {

    if (student.getId() > 10L && student.getName().equals("guo")

    student.getAge() > 20

    student.getGender().equals(Gender.女)

    student.isJoinsACM())

    aList.add(student);

    }

    }

    return aList2、;

    }

    代码运行不出

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

    ArrayList list1=(ArrayList) list.stream().filter(e->

    (e.getId()>10L&&e.getAge()>20&&e.getGender().equals(gender1)&&e.isJoinsACM()==true)).collect(Collectors.toList());

    list1.forEach(e->System.out.println(e));

    结果:

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

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

     

    5.2 GeneralStack接口的代码

    interface GeneralStack<T> {
    	public T push(T item);
    	public T pop();
    	public T peek();
    	public boolean empty();
    	public int size();
    }
    

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

    泛型后不限制元素类型,无须再强制类型转化,减少程序出错的机会

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

    3.1. 码云代码提交记录

  • 相关阅读:
    python2.7之打飞机(文末附素材链接)
    python画小猪佩奇
    什么叫递归
    DIV居中的几种方法
    什么是控制反转
    上传图片及时预览
    MVC与三层的区别
    From表单提交刷新页面?
    文件上传之form表单篇
    文件上传之伪Ajax篇
  • 原文地址:https://www.cnblogs.com/gysbettrer/p/6715479.html
Copyright © 2011-2022 走看看