1) 取值--- 取单链表中第 i 个元素的内容
顺序表里如何找到第i个元素?
L-> elem[i-1]
算法思路: 分别取出表中第 3 个元素和 第 15 个元素
链表是顺序存取结构 不是随机存储结构
2) 查找
1. 按值查找: 根据指定数据获取该数据所在的位置 (该数据的地址)
算法步骤:
1. 从第一个结点起, 依次和e相比较
2. 如果找到一个其值与e相等的数据元素, 则返回其在链表中的 "位置" 或 地址
3. 如果查遍整个链表都没有找到其值和e相等的元素, 则返回0 或 "NULL"
2. 按值查找---根据指定数据获取该数据位置序号
3) 插入---在第i个结点前插入值为 e 的新结点
思考一下: 步骤 ①和 ②能互换吗? 先执行②,后执行①,可以吗?
不可以哦! 会丢失 ai的地址
红色部分: 是代表如何做到把新的结点插入进去
4) 删除--- 删除第i个结点
算法步骤:
首先 找到 ai-1 的存储位置 p, 保存要删除的ai的值
其次 令 p->next 指向 ai+1
最后释放结点 ai 的空间
单链表的查找,插入, 删除算法时间效率分析
1.查找:
因线性链表只能顺序存取, 即在查找时要从头指针找起, 查找的时间复杂度为 O(n)
2. 插入和删除
因线性链表不需要移动元素, 只要修改指针, 一般情况下时间复杂度 为 O(1).
但是, 如果要在单链表中进行前插或删除操作, 由于要从头查找前趋结点, 所耗时间复杂度为 O(n).
5) 单链表的建立
1.头插法---元素插入在链表头部, 也叫前插法
原理:
算法的时间复杂度是: O(n)
2.尾插法--- 元素插入在链表尾部, 也叫做后插法