CS61B学习笔记 — Lecture4: SLLists, Nested Classes, Sentinel Nodes

本文详细介绍了如何使用Java实现SLList数据结构,包括IntNode内部类的创建,SLList类的构造及方法如addFirst(), getFirst(), addLast(), size()。文章还讨论了sentinel节点的引入,以解决数组为空时的操作问题,增强了数据结构的稳定性。" 112398748,9354537,理解与实现恺撒密码,"['加密技术', '信息安全', '编程', 'Python']

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

一、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的一个嵌套类。这么做的原因有三:

  1. 可以节省一点内存空间。
  2. 提高可读性和可维护性:因为如果一个类只对另外一个类可用,那么将它们放在一起,这更便于理解和维护。
  3. 提高封装性:给定两个类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():插入一个值到数组的头部。

  1. 创建一个节点,节点的item为想要插入的实数值
  2. 将该节点插入数组的最前面(目前为止,我们的数组只是单链的)

getFirst():得到数组中第一个节点的值。

/* adds x to the front of the list */
    public 
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值