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

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

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

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

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

1.链表的基本概念

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

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

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

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

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

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

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

2.向链表中添加元素

(1)在链表的开头添加元素87J28资讯网——每日最新资讯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)在链表的结尾添加元素87J28资讯网——每日最新资讯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)删除链表的第一个元素87J28资讯网——每日最新资讯28at.com

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

(2)删除链表的最后一个元素87J28资讯网——每日最新资讯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.实战案例:反转链表一个常见的面试问题是如何反转链表。我们可以使用迭代的方法来解决这个问题。87J28资讯网——每日最新资讯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

小结

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

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

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

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

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

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

    Redmi Pad评测:红米充满野心的一次尝试

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

    Raft算法:保障分布式系统共识的稳健之道

    1. 什么是Raft算法?Raft 是英文”Reliable、Replicated、Redundant、And Fault-Tolerant”(“可靠、可复制、可冗余、可容错”)的首字母缩写。Raft算法是一种用于在分布式系统
  • Golang 中的 io 包详解:组合接口

    Golang 中的 io 包详解:组合接口

    io.ReadWriter// ReadWriter is the interface that groups the basic Read and Write methods.type ReadWriter interface { Reader Writer}是对Reader和Writer接口的组合,
  • 大厂卷向扁平化

    大厂卷向扁平化

    来源:新熵作者丨南枝 编辑丨月见大厂职级不香了。俗话说,兵无常势,水无常形,互联网企业调整职级体系并不稀奇。7月13日,淘宝天猫集团启动了近年来最大的人力制度改革,目前已形成一
  • 年轻人的“职场羞耻感”,无处不在

    年轻人的“职场羞耻感”,无处不在

    作者:冯晓亭 陶 淘 李 欣 张 琳 马舒叶来源:燃次元“人在职场,应该选择什么样的着装?”近日,在网络上,一个与着装相关的帖子引发关注,在该帖子里,一位在高级写字楼亚洲金
  • 机构称Q2国内智能手机销量同比下滑4% vivo份额重回第1

    机构称Q2国内智能手机销量同比下滑4% vivo份额重回第1

    7月29日消息,根据市场调查机构Counterpoint Research公布的最新报告,2023年第2季度中国智能手机销量同比下降4%,创新自2014年以来第2季度销量新低。报
  • iQOO Neo8 Pro抢先上架:首发天玑9200+ 安卓性能之王

    iQOO Neo8 Pro抢先上架:首发天玑9200+ 安卓性能之王

    经过了一段时间的密集爆料,昨日iQOO官方如期对外宣布:将于5月23日推出全新的iQOO Neo8系列新品,官方称这是一款拥有旗舰级性能调校的作品。随着发布时
  • 最薄的14英寸游戏笔记本电脑  Alienware X14已可以购买

    最薄的14英寸游戏笔记本电脑 Alienware X14已可以购买

    2022年1月份在国际消费电子展(CES2022)上首次亮相的Alienware新品——Alienware X14现在已经可以购买了,这款笔记本电脑被誉为世界上最薄的 14 英寸游戏笔
  • 中关村论坛11月25日开幕,15位诺奖级大咖将发表演讲

    中关村论坛11月25日开幕,15位诺奖级大咖将发表演讲

    11月18日,记者从2022中关村论坛新闻发布会上获悉,中关村论坛将于11月25至30日在京举行。本届中关村论坛由科学技术部、国家发展改革委、工业和信息化部、国务
Top
Baidu
map