当前位置: 首页 > news >正文

备战蓝桥杯Day17 - 链表

链表

基本概念

链表是由一系列节点组成的元素集合。

每个节点包含两部分:数据域 item 、指向下一个节点的指针 next

通过节点之间的相互链接,形成一个链表

1. 链表的初始化

# 手动建立链表
# 链表的初始化
class Node(object):def __init__(self, item):self.item = itemself.next = next# 手动添加链表中的数据
a = Node(1)
b = Node(2)
c = Node(3)
d = Node(4)
# 将节点之间链接起来
a.next = b
b.next = c
c.next = d
# 可通过指针输出想要的数据
print(a)  # 1
print(a.next)  # 2
print(a.next.next)  # 3
print(a.next.next.next)  # 4 

手动添加数据的方式我们不怎么用,有专门的创建链表的方法 ,手动创建我们只需知道了解即可。

2.创建链表

(1).头插法

先把新的节点连到头节点(head)前面

 再把头节点head挪到这个新的元素上

代码实现
def creat_linklist_head(li):head = Node(li[0])   # 将列表中的第一个元素设为头节点for element in li[1:]:   # 循环遍历链表node = Node(element)  # 将链表中的元素设置为一个节点node.next = head   # 将元素直接插到头节点的前面head = node   # 再将头节点直接挪到前面return head   # 返回头节点

(2).尾插法 

 将尾指针指向下一个元素。

 再把尾指针先后挪。

代码实现
def creat_linklist_tail(li):head = Node(li[0])  # 将列表中的第一个元素设为头节点tail = head  # 当一开始只有一个节点的时候,头节点和尾节点是同一个for element in li[1:]:  # 循环遍历列表读取数据node = Node(element)   # 将列表中的元素设置为一个节点tail.next = node  # 将尾指针指向新添加的元素tail = node  # 尾指针向后移,移到最后一个元素上return head  # 返回头节点

3.遍历链表

当链表不为空时,直接循环打印当前元素,并不断指向下一个。

def print_linklist(lk):while lk:print(lk.item, end=" ")lk = lk.next# 集合尾插法进行测试
lk = creat_linklist_tail([1,2,3,4])
print_linklist(lk)

运行后可以正常给出遍历结果,但是我不理解他为什么会报错,我跟着视频中教程敲得代码,人家没报错为什么我的报错。等我研究研究。

http://www.lryc.cn/news/306887.html

相关文章:

  • 登录页设计新选择:毛玻璃和新拟态风格,非2.5D和插画风
  • 14:00面试,14:05就出来了,问的问题有点变态。。。
  • 关于纯前端想要变成全栈编写接口的学习推荐
  • Rust升级慢,使用国内镜像进行加速
  • Base64 编码 lua
  • 41.仿简道云公式函数实战-数学函数-SUMIF
  • 挑战30天学完Python:Day22 爬虫
  • AI:138-开发一种能够自动化生成艺术品描述的人工智能系统
  • 智慧城市建设的新里程碑:公共服务电子支付大屏
  • Netty之Decoder详解与实战
  • PCIe P2P DMA全景解读
  • 【Git】window下大小写不敏感问题处理
  • 【JS】【Vue3】【React】获取滚轮位置的方法:JavaScript、Vue 3和React示例
  • 什么是线程和进程?
  • MaxScale实现mysql8读写分离
  • 【c语言】内存函数
  • 规则引擎项目
  • Docker Image(镜像)
  • qgis启动提示Could not load qgis_app.dll
  • 数据分析---Python与sql
  • 【Oracle】玩转Oracle数据库(六):模式对象管理与安全管理
  • 微服务篇之限流
  • react脚手架
  • 【Vue3】插槽使用和animate使用
  • HarmonyOS—低代码开发Demo示例
  • Spring体系下解决请求统一加解密之ResponseBodyAdvice和RequestBodyAdvice
  • C# 经典:ref 和 out 的区别详解
  • Linux 系统添加虚拟内存的方法
  • PHP 函数四
  • 【Android】反编译APK及重新打包