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历史-设置时间段”, 然后搜索并截图

原文地址:https://www.cnblogs.com/zfy666/p/6682589.html