• 201521123080《Java程序设计》第7周学习总结


    1. 本周学习总结

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

    2. 书面作业

    1. ArrayList代码分析
    1.1 解释ArrayList的contains源代码

    • 源代码如下

    • 分析:contains方法中调用indexOf方法来判断是否包含对象。在indexOf方法中,如果对象为空,elementData[i]为空,返回i;如果对象不为空,调用equals方法,进行比较,如果与element[i]相同,返回i。

    1.2 解释E remove(int index)源代码

    • 源代码如下

    • 分析:查找此ArrayList中是否包含要找的元素,若有,返回true,否则返回false;

    1.3 结合1.1与1.2,回答ArrayList存储数据时需要考虑元素的类型吗?

    • ArrayList存储数据时不需要考虑元素的类型,它可以存储不同类型的元素,但要加上泛型。

    1.4 分析add源代码,回答当内部数组容量不够时,怎么办?

    • 源代码如下

    • 分析:先确定数组的容量,当内部数组容量不够时,增加数组长度。

    1.5 分析private void rangeCheck(int index)源代码,为什么该方法应该声明为private而不声明为public?

    • 源代码如下

    • 分析:检查是否越界,超出则抛出异常。用private声明别的用户或者类不能调用,而public则任何用户和类都可以调用。

    2. HashSet原理
    2.1 将元素加入HashSet(散列集)中,其存储位置如何确定?需要调用那些方法?

    • HashSet会先调用该对象的hashCode()方法得到其hashCode值,根据该值决定该对象在桶中存储位置。如果已有其他元素,则调用加入对象的equals()方法与已有元素进行比较。如果比较结果为假,则将对象插入。如果比较结果为真,则用新的值替换旧的值。如果有两个元素通过equals()方法比较返回true,而它们的hashCode()方法返回值不等,HashSet也会将它们存储在不同的位置。

    3. ArrayListIntegerStack
    题集jmu-Java-05-集合之5-1 ArrayListIntegerStack
    3.1 比较自己写的ArrayListIntegerStack与自己在题集jmu-Java-04-面向对象2-进阶-多态、接口与内部类中的题目5-3自定义接口ArrayIntegerStack,有什么不同?(不要出现大段代码)

    • 前者为ArrayList,无需考虑数组容量,后者为栈,需考虑大小;ArrayList可以直接找到元素,插入或删除。

    3.2 简单描述接口的好处.

    • 防止了代码重写,不同类可以使用,灵活性高。

    4. Stack and Queue
    4.1 编写函数判断一个给定字符串是否是回文,一定要使用栈,但不能使用java的Stack类(具体原因自己搜索)。请粘贴你的代码,类名为Main你的学号。

    import java.util.*;
    
    interface StringStack {
        public String push(String item);
        public String pop();
        public String peek();
        public boolean empty();
        public int size();
    }
    
    class ArrayListStringStack implements StringStack {
        private List<String> list;
    
        public ArrayListStringStack() {
            list = new ArrayList<String>();
        }
    
        @Override
        public String push(String item) {
            if (item == null)
                return null;
            list.add(item);
            return item;
        }
    
        @Override
        public String pop() {
            if (list.isEmpty())
                if (list.size() == 0)
                    return null;
            return list.remove(list.size() - 1);
        }
    
        @Override
        public String peek() {
            if (list.size() == 0)
                return null;
            return list.get(size() - 1);
        }
    
        @Override
        public boolean empty() {
            if (list.size() == 0)
                return true;
            return false;
        }
    
        @Override
        public int size() {
            return list.size();
        }
    
        @Override
        public String toString() {
            return list.toString();
        }
    
    }
    
    public class Main201521123080{
        public static void main(String[] args) {
        	Scanner sc=new Scanner(System.in);
            String x=sc.next();
            System.out.println(isHuiWen(x));
        }
    
    	private static boolean isHuiWen(String string) {
    		ArrayListStringStack list=new ArrayListStringStack();
    		char[] Array=string.toCharArray();
    		for (int i = 0; i < Array.length; i++) {
    			list.push(String.valueOf(Array[i]));
    		}
    		for (int i = 0; i < Array.length/2; i++) {
    			if(list.pop().equals(String.valueOf(Array[i])))
    				return true;
    		}
    		return false;
    	}
    }
    
    • 运行结果如下

    4.2 题集jmu-Java-05-集合之5-6 银行业务队列简单模拟。(不要出现大段代码)

    • 建立A、B两个队列,根据奇偶性放入其中,最后退出循环,将非空队列的对象全部输出。
    Queue<Integer> A=new LinkedList<Integer>();
    Queue<Integer> B=new LinkedList<Integer>();
    for(i=0;i<n;i++){
        x=in.nextInt();
        if(x%2==1) A.add(x);
        else B.add(x);
    }
    Integer Anum1 = A.poll();
            if(Anum1 != null){
                if(A.isEmpty()() &&  B.isEmpty())
                System.out.print(Anum1);
                else 
                    System.out.print(Anum1 + " ");  
            }
    
    Integer Anum2 = A.poll();
            if(Anum2 != null){
                if(A.isEmpty() && B.isEmpty())
                System.out.print(Anum2);
                else 
                    System.out.print(Anum2 + " ");  
            }
    }
    

    5. 统计文字中的单词数量并按单词的字母顺序排序后输出
    题集jmu-Java-05-集合之5-2 统计文字中的单词数量并按单词的字母顺序排序后输出 (不要出现大段代码)
    5.1 实验总结

    • 关键代码如下
    while (sr.hasNext()) {
                String x = sr.next();
                if (x.equals("!!!!!"))
                    break;
                else if (!sr.contains(x))
                    str.add(x);
            }
    

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

    题目集:jmu-Java-05-集合
    3.1. 码云代码提交记录

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

  • 相关阅读:
    c语言l博客作业04
    【 js 基础 】【 源码学习 】 深浅拷贝
    【 js 片段 】如何组织表单的默认提交?【亲测有效】
    【 js 性能优化】【源码学习】underscore throttle 与 debounce 节流
    【 js 片段 】移动端适配简易步骤
    【 js 模块加载 】【源码学习】深入学习模块化加载(node.js 模块源码)
    【 js 片段 】点击空白或者页面其他地方,关闭弹框
    【 js 算法类】这么全的数组去重,你怕不怕?
    【 js 工具 】如何使用Git上传本地项目到github?(mac版)
    【 js 工具 】如何在Github Pages搭建自己写的页面?
  • 原文地址:https://www.cnblogs.com/zfy666/p/6682589.html
Copyright © 2020-2023  润新知