当前位置:首页 > 科技  > 软件

五分钟搞懂链表实现:Python数据结构与算法

来源: 责编: 时间:2023-10-08 07:06:36 343观看
导读链表是一种由节点组成的线性数据结构,每个节点包含一个数据元素和一个指向下一个节点的指针。1.链表的基本概念(1)节点定义链表中的每一个元素都是一个节点,每个节点通常包含两部分:数据和下一个节点的引用。class Node:

链表是一种由节点组成的线性数据结构,每个节点包含一个数据元素和一个指向下一个节点的指针。qhp28资讯网——每日最新资讯28at.com

qhp28资讯网——每日最新资讯28at.com

1.链表的基本概念

(1)节点定义qhp28资讯网——每日最新资讯28at.com

链表中的每一个元素都是一个节点,每个节点通常包含两部分:数据和下一个节点的引用。qhp28资讯网——每日最新资讯28at.com

class Node:    def __init__(self, data):        self.data = data  # 节点存储的数据        self.next = None  # 默认下一个节点为空

(2)链表定义qhp28资讯网——每日最新资讯28at.com

链表通常有一个头节点来表示链表的开始。尾节点是链表中的最后一个节点,它的下一个节点引用为None。qhp28资讯网——每日最新资讯28at.com

qhp28资讯网——每日最新资讯28at.com

class LinkedList:    def __init__(self):        self.head = None  # 初始链表为空

2.向链表中添加元素

(1)在链表的开头添加元素qhp28资讯网——每日最新资讯28at.com

def add_first(self, data):    new_node = Node(data)   # 创建新的节点    new_node.next = self.head  # 将新节点指向当前的头节点    self.head = new_node    # 更新头节点为新节点LinkedList.add_first = add_first

(2)在链表的结尾添加元素qhp28资讯网——每日最新资讯28at.com

def add_last(self, data):    new_node = Node(data)    if self.head is None:  # 若链表为空,则直接将新节点设置为头节点        self.head = new_node        return    last_node = self.head  # 遍历到链表的尾部    while last_node.next:        last_node = last_node.next    last_node.next = new_node  # 在链表尾部添加新节点LinkedList.add_last = add_last

3.从链表中删除元素

(1)删除链表的第一个元素qhp28资讯网——每日最新资讯28at.com

def remove_first(self):    if self.head:        self.head = self.head.next  # 更新头节点为下一个节点LinkedList.remove_first = remove_first

(2)删除链表的最后一个元素qhp28资讯网——每日最新资讯28at.com

def remove_last(self):    if self.head is None:  # 若链表为空,直接返回        return    if self.head.next is None:  # 若链表只有一个元素,将头节点设置为空        self.head = None        return    second_to_last = self.head  # 找到倒数第二个节点    while second_to_last.next.next:        second_to_last = second_to_last.next    second_to_last.next = None  # 将倒数第二个节点的next设置为空,从而删除最后一个节点LinkedList.remove_last = remove_last

4.遍历链表

def print_list(self):    current_node = self.head  # 从头节点开始遍历    while current_node:        print(current_node.data, end=" -> ")        current_node = current_node.next  # 移动到下一个节点    print("None")LinkedList.print_list = print_list

5.查找链表中的元素

def search(self, target):    current_node = self.head  # 从头节点开始遍历    while current_node:        if current_node.data == target:  # 若找到目标数据,返回True            return True        current_node = current_node.next  # 移动到下一个节点    return False  # 遍历完链表后,未找到目标数据,返回FalseLinkedList.search = search

6.实战案例:反转链表一个常见的面试问题是如何反转链表。我们可以使用迭代的方法来解决这个问题。qhp28资讯网——每日最新资讯28at.com

def reverse(self):    prev = None  # 上一个节点    current = self.head  # 当前节点    while current:        next_node = current.next  # 记录下一个节点        current.next = prev  # 将当前节点指向上一个节点        prev = current  # 更新上一个节点为当前节点        current = next_node  # 移动到下一个节点    self.head = prev  # 更新头节点LinkedList.reverse = reverse# 使用示例ll = LinkedList()ll.add_last(1)ll.add_last(2)ll.add_last(3)ll.print_list()  # 输出:1 -> 2 -> 3 -> Nonell.reverse()ll.print_list()  # 输出:3 -> 2 -> 1 -> None

小结

链表提供了一种在内存中存储有序元素的方法,它的主要优势在于插入和删除操作的效率高,不需要移动其他元素。不过,链表的随机访问速度比数组慢,因为需要从头节点开始遍历。理解链表的结构和常用操作是计算机科学基础,也经常用于面试中。qhp28资讯网——每日最新资讯28at.com

本文链接:http://www.28at.com/showinfo-26-12388-0.html五分钟搞懂链表实现:Python数据结构与算法

声明:本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。邮件:2376512515@qq.com

上一篇: 七个国外高效开发者工具,让你的工作流程比德芙更加丝滑

下一篇: 仅需五分钟,使用Initializr快速开发Spring Boot应用

标签:
  • 热门焦点
  • Redmi Pad评测:红米充满野心的一次尝试

    从Note系列到K系列,从蓝牙耳机到笔记本电脑,红米不知不觉之间也已经形成了自己颇有竞争力的产品体系,在中端和次旗舰市场上甚至要比小米新机的表现来得更好,正所谓“大丈夫生居
  • Raft算法:保障分布式系统共识的稳健之道

    1. 什么是Raft算法?Raft 是英文”Reliable、Replicated、Redundant、And Fault-Tolerant”(“可靠、可复制、可冗余、可容错”)的首字母缩写。Raft算法是一种用于在分布式系统
  • 如何正确使用:Has和:Nth-Last-Child

    我们可以用CSS检查,以了解一组元素的数量是否小于或等于一个数字。例如,一个拥有三个或更多子项的grid。你可能会想,为什么需要这样做呢?在某些情况下,一个组件或一个布局可能会
  • Python异步IO编程的进程/线程通信实现

    这篇文章再讲3种方式,同时讲4中进程间通信的方式一、 Python 中线程间通信的实现方式共享变量共享变量是多个线程可以共同访问的变量。在Python中,可以使用threading模块中的L
  • JVM优化:实战OutOfMemoryError异常

    一、Java堆溢出堆内存中主要存放对象、数组等,只要不断地创建这些对象,并且保证 GC Roots 到对象之间有可达路径来避免垃 圾收集回收机制清除这些对象,当这些对象所占空间超过
  • 东方甄选单飞:有些鸟注定是关不住的

    文/彭宽鸿编辑/罗卿东方甄选创始人俞敏洪带队的“7天甘肃行”直播活动已在近日顺利收官。成立后一年多时间里,东方甄选要脱离抖音自立门户的传闻不绝于耳,“7
  • 半导体需求下滑 三星电子DS业务部门今年营业亏损预计超10万亿韩元

    7月17日消息,据外媒报道,去年下半年开始的半导体需求下滑,影响到了三星电子、SK海力士、英特尔等诸多厂商,营收明显下滑,部分厂商甚至出现了亏损。作为
  • 英特尔Xe-HP项目终止,将专注Xe-HPC/HPG系列显卡

    据10 月 31 日消息报道,英特尔高级副总裁兼加速计算系统和图形事业部总经理 表示,Xe-HP“ Arctic Sound” 系列服务器 GPU 已经应用于 oneAPI devcloud 云服
  • 荣耀Magic4 至臻版 首创智慧隐私通话 强劲影音系统

    2022年第一季度临近尾声,在该季度内,许多品牌陆续发布自己的最新产品,让大家从全新的角度来了解当今的手机技术。手机是电子设备中,更新迭代十分迅速的一款产品,基
Top