备战蓝桥杯Day17 - 链表

链表

基本概念

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

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

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

1. 链表的初始化

python 复制代码
# 手动建立链表
# 链表的初始化
class Node(object):
    def __init__(self, item):
        self.item = item
        self.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挪到这个新的元素上

代码实现
python 复制代码
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).尾插法

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

再把尾指针先后挪。

代码实现
python 复制代码
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.遍历链表

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

python 复制代码
def print_linklist(lk):
    while lk:
        print(lk.item, end=" ")
        lk = lk.next

# 集合尾插法进行测试
lk = creat_linklist_tail([1,2,3,4])
print_linklist(lk)

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

4.在指定位置插入元素

实现在3和5之间插入数字4.

为了防止数据丢失,首先把节点4连到节点5上,将p.next -> curNode.next

再将curNode的指针指向p,实现链接。curNode.next -> p

代码实现

python 复制代码
class LinkedList:  
    def __init__(self):  
        self.head = None  
  
    def insert(self, data, position=0):  
        new_node = Node(data)  
  
        if self.head is None:  
            self.head = new_node  
            return  
  
        if position == 0:  
            new_node.next = self.head  
            self.head = new_node  
            return  
  
        current = self.head  
        index = 0  
  
        while current is not None and index < position - 1:  
            current = current.next  
            index += 1  
  
        if current is not None:  
            new_node.next = current.next  
            current.next = new_node  
  
    def print_list(self):  
        current = self.head  
        while current:  
            print(current.data)  
            current = current.next  
  
# 使用  
ll = LinkedList()  
ll.insert(1)  
ll.insert(2)  
ll.insert(3, 1)  # 在位置1插入数字3,链表现在变为 1 3 2  
ll.print_list()  # 输出: 1 3 2
相关推荐
kyle~12 分钟前
OpenCV---特征检测算法(ORB,Oriented FAST and Rotated BRIEF)
人工智能·opencv·算法
初学小刘20 分钟前
决策树:机器学习中的强大工具
算法·决策树·机器学习
nightunderblackcat21 分钟前
进阶向:人物关系三元组,解锁人物关系网络的钥匙
开发语言·python·开源·php
山顶风景独好22 分钟前
【Leetcode】随笔
数据结构·算法·leetcode
站大爷IP37 分钟前
Pandas与NumPy:Python数据处理的双剑合璧
python
站大爷IP1 小时前
Python枚举进化论:IntEnum与StrEnum的实战指南
python
甄超锋1 小时前
python sqlite3模块
jvm·数据库·python·测试工具·django·sqlite·flask
科大饭桶1 小时前
C++入门自学Day11-- String, Vector, List 复习
c语言·开发语言·数据结构·c++·容器
lxmyzzs2 小时前
【图像算法 - 16】庖丁解牛:基于YOLO12与OpenCV的车辆部件级实例分割实战(附完整代码)
人工智能·深度学习·opencv·算法·yolo·计算机视觉·实例分割
R-G-B2 小时前
OpenCV Python——Numpy基本操作(Numpy 矩阵操作、Numpy 矩阵的检索与赋值、Numpy 操作ROI)
python·opencv·numpy·numpy基本操作·numpy 矩阵操作·numpy 矩阵的检索与赋值·numpy 操作roi