<<数据结构与算法>>---笔记(4) --- 单链表基本操作的实现

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.尾插法--- 元素插入在链表尾部, 也叫做后插法

                

 

                

  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值