Python-链表数据结构学习(1)

一、什么是链表数据?

链表是一种通过指针串联在一起的数据结构,每个节点由2部分组成,一个是数据域 ,一个是指针域 (存放下一个节点的指针)。最后一个节点的指针域指向null (空指针的意思),链表的入口节点称为链表的头结点 也就是head

链表结构如下图

二、链表的类型

1、单链表每个节点的指针指向一个方向,只可单方向查询数据,如上图所示。

2、双链表,每个节点可以有2个指针域,既可指向下一个节点,也可指向上一个节点,双链表既可以向前查询,也可以向后查询。

如图3、循环链表:链表首尾相连,可以用来解决约瑟夫环问题。如图
三、链表的存储方式

链表的存储于数组不同,数组在空间中可以是连续的,而链表是通过指针域的指针将不连续的数据存储在空间各个节点中的,因此指针节点 在链表数据的应用中非常关键。所以链表中的节点在内存中不是连续分布的 ,而是散乱分布在内存中的某地址上,分配机制取决于操作系统的内存管理。

四、链表的定义

了解了链表的结构组成,我们来了解一下链表的Python 实现,链表作为一个类,他需要构造。

复制代码
class ListNode:
    def __init__(self, val, next=None):##定义一个列表函数,包含数据值和指针()
        self.val = val #定义列表节点的self.val为val
        self.next = next #定义列表指针的self.next为next

五、常见的链表操作

1、删除节点

如图想要删除D节点,就要先将D节点上一个指针指向E节点,在Python语言中,会自动将D节点释放掉,此时就可以删除D节点了。

2、节点添加
如图想要在D节点前添加F节点,需要先把C节点指向F节点,然后再把F节点的指针指向D节点,在这个过程中Python系统会自动释放C到D的指针指向。

链表的增添和删除都是O(1)操作,也不会影响到其他节点。

但是要注意,要是删除第五个节点,需要从头节点查找到第四个节点通过next指针进行删除操作,查找的时间复杂度是O(n)。

六、链表和数组操作比较

数组在定义的时候,长度就是固定的,如果想改动数组的长度,就需要重新定义一个新的数组。

链表的长度可以是不固定的,并且可以动态增删, 适合数据量不固定,频繁增删,较少查询的场景。

Leetcode203题

复制代码
# Definition for singly-linked list.
# class ListNode:
#     def __init__(self, val=0, next=None):
#         self.val = val
#         self.next = next
class Solution:
    def removeElements(self, head: Optional[ListNode], val: int) -> Optional[ListNode]:
        cur=dummy=ListNode(next=head) ##构建一个虚拟哨兵节点,使得他的指针指向头结点
        while cur.next: ##当当前节点的指针存的时候
            if cur.next.val==val: ##如果当前节点的下一个节点的值等于指定的值,
                cur.next=cur.next.next #则删除下一个节点
            else:
                cur=cur.next #否则当前链表向下一个节点移动
        return dummy.next #返回链表(因为dummy是头结点前的一个虚拟节点,所以返回的是dummy.next)
复制代码
# Definition for singly-linked list.
# class ListNode:
#     def __init__(self, val=0, next=None):
#         self.val = val
#         self.next = next
class Solution:
    def reverseList(self, head: Optional[ListNode]) -> Optional[ListNode]:
        cur=head
        pre=None
        while cur:
            tem=cur.next##保存cur后续数据
            cur.next=pre##cur指针方向改变
            pre=cur ##把当前的cur付给pre,进行下一次循环
            cur=tem ##把之前保存的cur后续数据再赋值给当前的cur,进行下一次循环
        return pre
相关推荐
CSharp精选营2 天前
关系型 vs 非关系型:从原理到选型,一文搞定数据库核心分类
数据结构·nosql·关系型数据库·非关系型数据库·技术选型
刘马想放假5 天前
Modbus 全栈技术解析:TCP、RTU、ASCII、RTU over TCP
数据结构·网络协议
北域码匠6 天前
冒泡排序太慢?鸡尾酒排序双向优化,原生 C# 零第三方库完整代码
数据结构·排序算法·泛型·c# 算法·鸡尾酒排序·原生 c# 开发·冒泡排序优化·嵌入式算法
Darling噜啦啦13 天前
列表转树算法深度解析:从 Map 到 Reduce 的两种实现,面试高频考点
数据结构·算法·面试
通信小呆呆14 天前
当算法有了“五感”:多模态数据融合如何向人体感官协同学习?
人工智能·学习·算法·机器学习·机器人
H__Rick14 天前
自动对焦学习-3
人工智能·学习·计算机视觉
Daisy Lee14 天前
量化学习-第1章-什么是量化金融
学习·金融·datawhale
小小工匠14 天前
Redis - 事务机制:能实现 ACID 属性吗
数据结构·redis·性能优化·并发·持久化
Alsn8614 天前
等待学习-学习目录:Docker 容器安全攻防
学习·安全·docker
玖玥拾14 天前
C/C++ 数据结构(七)栈、容器适配器
c语言·数据结构·c++··容器适配器