201621123053《Java程序设计》第八周学习笔记
1. 本周学习总结
以你喜欢的方式(思维导图或其他)归纳总结集合相关内容。

2. 书面作业
1. ArrayList代码分析
1.1 解释ArrayList的contains源代码
查询jdk文档得知:
-
public boolean contains(Object o) { return indexOf(o) >= 0; } - 如果此列表中包含指定的元素,则返回 true。更确切地讲,当且仅当此列表包含至少一个满足 (onull ? enull : o.equals(e)) 的元素 e 时,则返回 true
1.2 解释E remove(int index)源代码
查询jdk文档得知:
-
源代码如下:
public E remove(int index) { rangeCheck(index); modCount++; E oldValue = elementData(index); int numMoved = size - index - 1; if (numMoved > 0) System.arraycopy(elementData, index+1, elementData, index, numMoved); elementData[--size] = null; // clear to let GC do its work return oldValue; } -
移除此列表中指定位置上的元素。向左移动所有后续元素(将其索引减 1)。
1.3 结合1.1与1.2,回答ArrayList存储数据时需要考虑元素的具体类型吗?
答:不需要考虑元素的具体类型。ArrayList存储数据的类型对象为object,而object是所有类的父类。
1.4 分析add源代码,回答当内部数组容量不够时,怎么办?
源代码如下:
public boolean add(E e) {
ensureCapacityInternal(size + 1); // Increments modCount!!
elementData[size++] = e;
return true;
}
第一行中的ensureCapacityInternal(size + 1)源代码如下:
private void ensureCapacityInternal(int minCapacity) {
if (elementData == DEFAULTCAPACITY_EMPTY_ELEMENTDATA) {
minCapacity = Math.max(DEFAULT_CAPACITY, minCapacity);
}
ensureExplicitCapacity(minCapacity);
}
查询得知:
- ensureCapacityInternal这个方法首先判断了当前的对象数组是不是默认的空数组,如果是的话,那么就在默认容量(10)和需要的容量中取一个最大值,然后把得到的这个值传递给下一个函数。
- 这样以来,当首次插入对象时,实际上就相当于构造了一个长度为10的对象数组。
所以如果内部数组容量不够,就必须进行扩容。
扩容通过newCapacity = oldCapacity + (oldCapacity >> 1);这段代码实现,实际上就是将新的容量变为原来容量的1.5倍。
1.5 分析private void rangeCheck(int index)源代码,为什么该方法应该声明为private而不声明为public?
-
源代码如下:
private void rangeCheck(int index) { if (index >= size) throw new IndexOutOfBoundsException(outOfBoundsMsg(index)); } -
声明为private我觉得是因为它并不是一个外部方法,仅仅是在
public E remove(int index)中起检验作用,因此需要避免让外界因素的干扰,保证不会出现数据的判断是否溢出出现问题。
参考资料:http://blog.csdn.net/u010723709/article/details/45647447
2. HashSet原理
2.1 将元素加入HashSet(散列集)中,其存储位置如何确定?需要调用那些方法?
答:将元素加入HashSet时,首先用hashCode()方法计算出这个对象的Hash码,然后再根据Hash码到相应的存储区域,再进行加入。
2.2 将元素加入HashSet中的时间复杂度是多少?是O(n)吗?(n为HashSet中已有元素个数)
答:时间复杂度应为O(1),因为是直接计算出哈希码,而不是一个一个比较得到储存位置的。
3. ArrayListIntegerStack
题集jmu-Java-05-集合之ArrayListIntegerStack
3.1 比较自己写的ArrayListIntegerStack与自己在题集jmu-Java-04-面向对象2-进阶-多态、接口与内部类中的题目自定义接口ArrayIntegerStack,有什么不同?(不要出现大段代码)
- 未使用ArrayList接口时,在内部定义了数组Stack和指针top,以达到栈的目的。所有的操作都是基于Stack数组和top指针完成的。
- 使用了ArrayList接口后,所有的操作均可用ArrayList类的方法,如add(),size()等等,操作更加方便。
3.2 结合该题简单描述接口的好处,需以3.1为例详细说明,不可泛泛而谈。
public Integer push(Integer item),入栈操作。未使用接口时需要让数据插入top位置,之后top++完成操作。使用接口后直接使用add方法就可以了。十分方便public Integer pop(),出栈操作,未使用接口时让top--,然后输出top-1对应位置的值,如果top=1最后返回空。使用接口后直接使用remove方法。public Integer peek(),取栈顶元素,未使用接口时输出top-1对应位置的值,使用接口后直接使用get方法。public boolean empty(),判断栈是否为空,未使用接口时判断top是否=0,使用接口后调用size方法判断其是否为0;public int size(),输出栈的大小,未使用接口时返回top,使用接口后直接调用size方法并返回。- 综上所述,使用接口后代码更加简洁明了,更方便读写。
4. Stack and Queue
4.1 编写函数判断一个给定字符串是否是回文,一定要使用栈(请利用Java集合中已有的类),但不能使用java的Stack类(具体原因自己搜索)与数组。请粘贴你的代码,类名为Main你的学号。
- 输入字符串str,用str.toCharArray()将其分解成一个一个字符储存在word数组中。
- 将word数组内的元素全部入栈。
- 令i=0,bol=true。比较word数组第i个元素与栈顶元素,若相等,出栈,i++;循环直到全部比较结束,若不相等则退出循环,bol为假。
- 比较结束后,若bol为假,则不是回文;若bol为真,则是回文。
![]()
测试数据


4.2 题集jmu-Java-05-集合之银行业务队列简单模拟(只粘贴关键代码)。请务必使用Queue接口,并说明你使用了Queue接口的哪一个实现类?
- 我用了LinkedList实现类。
- 输入m个数字,若输入的数字是偶数进入B队列,否则进入A队列。
- 当A.size()>=2*B.size()时,A队列元素出队两次,B队列元素出队一次,直到B队列为空,随后将A队列元素全部输出。
- 当A.size()<2*B.size()时,A队列元素出队两次,B队列元素出队一次,直到A队列为空,随后将B队列元素全部输出。

5. 统计文字中的单词数量并按单词的字母顺序排序后输出
题集jmu-Java-05-集合之5-2 统计文字中的单词数量并按单词的字母顺序排序后输出 (作业中不要出现大段代码)
5.1 实验总结
答:
- 定义words集合,用Treeset来存储数据,输入文章时,将单词words.add()进集合中,若出现!!!!则结束输入。
- 输出words.size(),输出单词数量
- 当words.size()<10时,遍历输出words中所有的元素。当words.size()>10时,输出10次words中的元素。
- 本题用Treeset来储存数据,是因为Treeset具有排序功能且不添加重复的元素。
3.码云及PTA
题目集:jmu-Java-05-集合
3.1. 码云代码提交记录
在码云的项目中,依次选择“统计-Commits历史-设置时间段”, 然后搜索并截图

3.2 截图PTA题集完成情况图
需要有两张图(1. 排名图。2.PTA提交列表图)


3.3 统计本周完成的代码量
需要将每周的代码统计情况融合到一张表中。
| 周次 | 总代码量 | 新增代码量 | 总文件数 | 新增文件数 |
|---|---|---|---|---|
| 1 | 200 | 200 | 3 | 3 |
| 2 | 308 | 108 | 7 | 4 |
| 3 | 571 | 263 | 16 | 9 |
| 5 | 833 | 262 | 19 | 3 |
| 6 | 1241 | 408 | 27 | 8 |
| 7 | 1784 | 543 | 34 | 7 |
| 8 | 1901 | 117 | 36 | 2 |
| 9 | 2109 | 325 | 45 | 9 |

浙公网安备 33010602011771号