zoukankan      html  css  js  c++  java
  • java第八周学习总结

    1. 本周学习总结

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

    2. 书面作业

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

    2.1 实验总结

    Iterator<String> it=list.iterator();
    		while(it.hasNext()){
    		String x=it.next();
    			if(x.equals(str)){
    				it.remove();
    

    在进行删除操作时,如果直接用list遍历,会出现答案错误的情况,所以需要迭代器进行操作,因为迭代器删除是,是不会改变迭代的下标的。

    3.统计文字中的单词数量并按出现次数排序(题目5-3)

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

    首先将输入的单词取出来放入map中,并且统计他们的出现次数;接着使用Comparator接口自定义一个排序方法,然后按照题目的要求输出总词数以及排名前十的词就可以了。

    3.2 实验总结

    将单词放入map中,需要分类处理,如果map中已经有了,那么只要value加一就可以了,如果没有,那就map.put(key,1);接着就是Comparator接口进行排序,先是比较次数o2.getValue()-o1.getValue(),如果相等,那就比较key,o1.getKey().compareTo(o2.getKey())

    3.3 提交截图

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

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

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

    1.建立TreeMap,Map<String,ArrayList<Integer>> word=new TreeMap<String,ArrayList<Integer>>(); 2.接着创建一个ArrayList,将输入的句子存放进去。 3.然后输出每个单词出现的段数。 4.判断输入的单词属于哪一行,输出段数并且将这短话也打印出来。

    4.3 实验总结

    本题主要使用了TreeMap,把输入的语段放入ArrayList中,查找出所有单词对应的段落。在统计单词的时候,要一段一段的读取,并自定义用空格对单词区分,因为后面需要对单词所在行数查询。

    5.Stream与Lambda

    编写一个Student类,属性为:

    private Long id;
    private String name;
    private int age;
    private Gender gender;//枚举类型
    private boolean joinsACM; //是否参加过ACM比赛
    创建一集合对象,如List,内有若干Student对象用于后面的测试。

    5.1 使用传统方法编写一个方法,将id>10,name为zhang, age>20, gender为女,参加过ACM比赛的学生筛选出来,放入新的集合。在main中调用,然后输出结果。

    package jihe;
    
    import java.util.ArrayList;
    import java.util.Set;
    enum Gender {  
          female, male
        } 
    class Student
    {
        private Long id;
        private String name;
        private int age;
        private Gender gender;//枚举类型
        private boolean joinsACM; //是否参加过ACM比赛
    
        
        public Student(Long id, String name, int age, Gender gender, boolean joinsACM) {
    
            this.id = id;
            this.name = name;
            this.age = age;
            this.gender = gender;
            this.joinsACM = joinsACM;
        }
    
        @Override
        public String toString() {
            return "Student [id=" + id + ", name=" + name + ", age=" + age + ", gender=" + gender + ", joinsACM=" + joinsACM
                    + "]";
        }
    
        public Student find()
        {
            if(this.id>10L&&this.name.equals("zhang")&&this.age>20&&this.gender==Gender.female&&this.joinsACM)
            {
                Student str=new Student(this.id,this.name,this.age,this.gender,this.joinsACM);
                return str;
            }
            
            else
                return null;
            
        }
    }
    public class test {
    
        public static void main(String[] args) {
            ArrayList<Student> list=new ArrayList<Student>();
            Student x=new Student(20L,"zhang",21,Gender.female,true);
            Student y=new Student(11L,"li",20,Gender.male,false);
            Student z=new Student(9L,"zhang",21,Gender.female,true);
            Student d=new Student(12L,"zhang",22,Gender.female,true);
            list.add(x);
            list.add(y);
            list.add(z);
            list.add(d);
            for (Student student : list) {
                System.out.println(student.find());
            }
        }
    
    }
    

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

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

    需要增加 student != null,对student是否非空进行判断

    6.泛型类:GeneralStack(题目5-5)

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

    6.2 GeneralStack接口的代码

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

    好处:例如在pta题目5-1所定义IntegerStack接口,只能用于存放Integer类型的数据,很不方便。但是如果使用泛型,在定义类时,不必直接就决定类的类型,在main中调用时,可以创建多个不同类型的类,方便。

    7.泛型方法

    基础参考文件GenericMain,在此文件上进行修改。

    7.1 编写方法max,该方法可以返回List中所有元素的最大值。List中的元素必须实现Comparable接口。编写的max方法需使得String max = max(strList)可以运行成功,其中strList为List类型。也能使得Integer maxInt = max(intList);运行成功,其中intList为List类型。

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

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

    3.1. 码云代码提交记录

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

  • 相关阅读:
    CF948D Perfect Security
    bzoj 1015 [JSOI2008]星球大战starwar
    XJOI 7191 Genius ACM
    bzoj 1491 [NOI2007]社交网络
    CF1066F Yet another 2D Walking
    iOS main函数讲解
    iOS 邓白氏编码的申请
    iOS 开发与H5交互(JavaScriptCore框架的使用)
    iOS 开发之RunLoop
    iOS 蓝牙开发之(CoreBlueTooth)
  • 原文地址:https://www.cnblogs.com/lsl321/p/6714109.html
Copyright © 2011-2022 走看看