zoukankan      html  css  js  c++  java
  • 201521123067 《Java程序设计》第8周学习总结

    201521123067 《Java程序设计》第8周学习总结


    1. 本周学习总结

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


    2. 书面作业

    Q1.List中指定元素的删除题集jmu-Java-05-集合之4-1

    1.1 实验总结

    ●public static void remove(List list, String str)这个函数的编写难度不大,我首先在JDK文档中查看了List,找到了indexOf(Object o)方法和remove(int index)方法,接着运用indexOf(Object o)方法找出str所在的位置,然后运用remove(int index)方法将该位置上的元素删除就可以了。
    ●public static List convertStringToList(String line)这个函数编写的时候有点困难,起初是不理解题目意思,后来通过百度搜索明白了意思,然后在JDK文档中查看了Arrarys,找到asList(T... a)方法,认真看明白之后学会了使用。
    

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

    Q2.统计文字中的单词数量并按出现次数排序(尽量不要出现代码)题集jmu-Java-05-集合之5-3统计文字中的单词数量并按出现次数排序

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

    步骤如下:
    1、首先建立一个Map.Entry类型的对象。
    2、接着将输入的单词一一存储进去,放进Map的键中,并且对出现的次数累加,放进Map的值中。
    3、然后取出每个值,相减比较出大小。
    
    伪代码如下:
    Map<String, Integer> map = new TreeMap<String, Integer>();
    while (sc.hasNext()) {
    			将输入的单词存储进键里;
                            对单词出现的次数进行计数,并放进值里
    		}
    List<Map.Entry<String, Integer>> m = new ArrayList<Map.Entry<String, Integer>>(map.entrySet());
    		Collections.sort(m, new Comparator<Map.Entry<String, Integer>>() {
    			@Override
    			public int compare(Entry<String, Integer> o1, Entry<String, Integer> o2) {
    				return (o2.getValue() - o1.getValue());
    			}
    		});
    

    2.2 实验总结

    ●在本题中首先要学会Map的使用,查询JDK文档后就能知道如何使用了,然后我选择了用Map.Entry做这道题。
    ●接着使用put方法,将单词以及频数一一存储到键和值中。
    ●最后将Map中的前十对键值输出。
    

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

    Q3.倒排索引(尽量不要出现代码)题集jmu-Java-05-集合之5-4

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

    TreeMap建立一个新的Map;
    while (有输入) {
    		if ("!!!!!") {
    	       退出;
    			} 
    		else {
    			储存单词和对应的行数;
    			}
    			行数++;
    }
    for each {
    			System.out.println(所有单词以及对应的行数);
    if (键为空) {
    				System.out.println("found 0 results");
    	}
    while (有输入) {
    				输入要查询的单词;
    				retainAll(map.get(单词));
    			}
    			if (该单词不存在) {
    				System.out.println("found 0 results");
    			} 
    			else {
    				System.out.println(该单词对应的行数);
    				for each {
    					System.out.println(整行的单词);
    				}
    			}
    

    3.2 实验总结

    ●首先要建立一个Map来容纳单词,将单词放入键中,将该单词出现的行数放入值中。接着根据键的大小进行排序再输出。最后根据查询的键输出其对应的值,并且输出相应的整行内容。
    ●本题的难点在于行数的存储。
    

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

    Q4.Stream与Lambda 编写一个Student类,属性为:

    private Long id;
    private String name;
    private int age;
    private Gender gender;//枚举类型
    private boolean joinsACM; //是否参加过ACM比赛
    

    Q4.创建一集合对象,如List,内有若干Student对象用于后面的测试。

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

    代码如下:
    public ArrayList<Student> select(ArrayList<Student> stu)
        {
            ArrayList<Student> stus = new ArrayList<Student>();
            for(Student s : stu)
            {
                if(s.id>10L&&s.name.equals("zhang")&&s.age>20&&s.gender==s.female&&s.joinsACM)
                {
                    stus.add(s);
                 }
            } 
            return stus;
        }
    
    运行结果如下:

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

    代码如下:
    ArrayList<Student> stus = (ArrayList<Student>) stu.parallelStream().filter(s -> (s.id>10L&&s.name.equals("zhang")&&s.age>20&&s.gender==s.female&&s.joinsACM).collect(Collectors.toList());
    
    运行结果如下:

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

    代码如下:
    ArrayList<Student> stus = (ArrayList<Student>) stu.parallelStream().filter(s -> s != null &&(s.id>10L&&s.name.equals("zhang")&&s.age>20&&s.gender==s.female&&s.joinsACM).collect(Collectors.toList());
    

    Q5.泛型类:GeneralStack题集jmu-Java-05-集合之5-5 GeneralStack

    5.1 GeneralStack接口的代码

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

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

    答:泛型的好处:不把接口局限于某种类型,我个人觉得这样可以使得每种方法的利用率都提高很多,不需要为了一种类型就创建一个接口或者一种方法,有了泛型,就像是有了个万能膏药一样,很方便,只需要在使用的时候确定好类型就可以了。但是不知道为什么在eclipse上已经运行正确了,在PTA上提交一直显示答案错误。
    

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

    Q6.泛型方法

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

    编写出的方法max代码如下:
    public static <T extends Comparable<T>> T max(T strList) {
    		T max = Collections.max((Collection<? extends T>) strList);
    		return max;
    	}
    

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

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

    3.1. 码云代码提交记录

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

  • 相关阅读:
    Elasticsearch
    区块链 blockchain
    IM协议
    MQ,互联网架构解耦神器
    服务中的 API 网关(API Gateway)
    OSI七层与TCP/IP五层网络架构详解
    JQ input标签限制输入数字或字母
    c:forEach用法
    jquery在线引用
    JSONObject使用方法
  • 原文地址:https://www.cnblogs.com/yjliao/p/6691326.html
Copyright © 2011-2022 走看看