数据结构-第二期——链表(Python)

目录

前言 

链表

 单向链表

双向链表 

 Python链表的实现

1、用list实现 

2、书写链表实现 

定义结点

列表操作

插入

列表实现时间测试:

 蓝桥杯实战训练1:自行车停放

法一:列表list实现

法二:手写链表

 蓝桥杯实战训练2: 约瑟夫环


前言 

数组的缺点

1) 需要占用连续的空间。

若某个数组很大,可能没有这么大的连续空间给它用。

2)不方便删除和插入

例如删除数组中间的一个数据,需要把后面所有的数据往前挪填补这个空位,产生大量的拷贝开销。中间插入数据,也同样不方便操作

(本文参考罗勇军老师的蓝桥云课)

链表

链表的定义:是一组数据项的集合,其中每个数据项都是一个节点的一部分,每个节点还包含指向下一个节点的链接

链表的结构:data为自定义的数据,next为下一个节点的地址。 

  • 不需要把数据存储在连续的空间上。(把空间分开存储,用指针连接)
  • 优势删除和增加数据都很方便
  • 链表可以看成是用指针串起来的数组,它用一串位于任意位置的存储单元存线性表的数据元素,这些存储单元可以是连续的,也可以不连续

  • 4
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 2
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

小叶pyか

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值