Lecture4: SLLists, Nested Classes, Sentinel Nodes
一、IntNode类
在Lecture3的学习中,我们发现IntList类中它的数据结构有一些裸露,即所有的方法、变量、构造方法都在一个类中。这不太符合Java语言创造数据结构的习惯。所以在这一章中,我们希望可以创造一件“衣服”,通过这个“衣服”,即中间类,架起外部类接触到内部数据结构的桥梁。
首先我们构造内部的数据结构IntNode类:
public class IntNode {
public int item;
public IntNode next;
/*构造函数*/
public IntNode(int i, IntNode n){
item = i;
next = n;
}
二、SLList类
接下来,我们需要给这个简单的数据结构加上 “衣服”,即SLList类。如图所示:
与Lecture3类似,我们首先需要一个头结点,作为list的起始节点。
private IntNode first;
这里我们使用关键字private:
- SLList类外的其他类不可接触、改变first这个节点,避免由于程序员误操作影响整个数据结构的正常运行。
- 因此,如果你只是一个临时的程序员,谨慎更改表明private的内容
1. IntNode类嵌套到SLList类中
我们可以将IntNode类嵌套到SLList类中,这时IntNode成为SLList的一个嵌套类。这么做的原因有三:
- 可以节省一点内存空间。
- 提高可读性和可维护性:因为如果一个类只对另外一个类可用,那么将它们放在一起,这更便于理解和维护。
- 提高封装性:给定两个类A和B,如果需要访问A类中的私有成员,则可以将B类封装在A类中,这样不仅B类可以访问A类中的私有成员,并且可以在外部隐藏B类本身。
注:非静态嵌套类(内部类)可以访问外部类的其他成员,即使该成员是私有的。而静态嵌套类(嵌套类)只能访问外部类的静态成员。
public class SLList {
private static class IntNode {
public int item;
public IntNode next;
public IntNode(int i, IntNode n) {
item = i;
next = n;
}
}
private IntNode first;
}
PS: 使嵌套类IntNode私有化,外部类SLList的实例无法实例化IntNode类;
如果嵌套类不需要使用外部类中的任何成员则可以给嵌套类添加static关键词。
2. SLList类的构造函数
当我们想创建一个SLList时,该类中的数据结构是一个一个的节点,每个节点中包含一个item(Integer),一个next节点(IntNode)指向下一个节点。因此在Lecture3中,我们用一下代码创建数组。
IntList L = new IntList(10,null);
但是在实际编码世界中,我们并不希望指定null值:因为麻烦且可读性差。我们希望给一个Integer,就可以很方便直接的构建,因此改进代码如下:
public SLList(int x){
first = new IntNode(x,null);
}
3. 给SLList类添加addFirst()和getFirst()方法
根据之前所说,SLList类使我们数据结构的一件“衣服”,所以它不仅能够创建数组,还要能操作该数组。
我们为他创建两个方法分别为addFirst()和getFirst():
addFirst():插入一个值到数组的头部。
- 创建一个节点,节点的item为想要插入的实数值
- 将该节点插入数组的最前面(目前为止,我们的数组只是单链的)
getFirst():得到数组中第一个节点的值。
/* adds x to the front of the list */
public