【数据结构和算法】链表实现
【摘要】 目录一、前言二、链表的简介三、单向链表的API设置 代码实现结点类:链表的设置结点类少不了 成员变量和构造方法 清空链表,链表的长度,链表是否为空 获取指定位置处的元素 插入元素t(在链表的最后以结点后插入元素) 在指定i处,添加元素t 删除指定位置i处的元素并返回被删除的元素 查找元素t在链表中第一次出现的位置提供一个遍历的方法,实现Iterable接口全部代码概览:测试类下:运行效果...
目录
四、鲁迅说:一个是关于head.next,另一个也是head.next
一、前言
链表是一个和数组不一样的存储方式。我们都知道数组的存储地址是连续的,这样就不能很好的利
用好内存空间,而链表就解决了这个问题,链表是一存储地址不连续的的存储结构,这样的好处
就是能节省空间。
二、链表的简介
链表是由一系列的结点构成的,链表的第一个元素为头结点,头结点的特点是;不存放具体的数
表示单链表的表头,比如要找一个结点就是从头结点一个一个往下找的。
每一个结点有一个类似于指针的next,用来指向下一个结点,和一个date区域用于存储数据
头结点不存放数据,最后一个结点不指向null。
三、单向链表的API设置
代码实现
结点类:链表的设置结点类少不了
成员变量和构造方法
清空链表,链表的长度,链表是否为空
获取指定位置处的元素
插入元素t(在链表的最后以结点后插入元素)
在指定i处,添加元素t
删除指定位置i处的元素并返回被删除的元素
查找元素t在链表中第一次出现的位置
提供一个遍历的方法,实现Iterable接口
全部代码概览:
测试类下:
运行效果图:
四、鲁迅说:一个是关于head.next,另一个也是head.next
有关于左右边的.next解读:
左边的.next表示的是指向,右边的.next表示的下一个元素。
一般来说在左边的是指向,在右边的是下一个元素。(这里.next前可以是任意非null结点)
head.next!=null一样的道理。
【版权声明】本文为华为云社区用户原创内容,转载时必须标注文章的来源(华为云社区)、文章链接、文章作者等基本信息, 否则作者和本社区有权追究责任。如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱:
cloudbbs@huaweicloud.com
- 点赞
- 收藏
- 关注作者
评论(0)