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

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

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

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

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

1.链表的基本概念

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

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

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

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

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

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

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

2.向链表中添加元素

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

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

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

小结

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

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

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

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

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

标签:
  • 热门焦点
  • 服务存储设计模式:Cache-Aside模式

    Cache-Aside模式一种常用的缓存方式,通常是把数据从主存储加载到KV缓存中,加速后续的访问。在存在重复度的场景,Cache-Aside可以提升服务性能,降低底层存储的压力,缺点是缓存和底
  • 分享六款相见恨晚的PPT模版网站, 祝你做出精美的PPT!

    1、OfficePLUSOfficePLUS网站旨在为全球Office用户提供丰富的高品质原创PPT模板、实用文档、数据图表及个性化定制服务。优点:OfficePLUS是微软官方网站,囊括PPT模板、Word模
  • 量化指标是与非:挽救被量化指标扼杀的技术团队

    作者 | 刘新翠整理 | 徐杰承本文整理自快狗打车技术总监刘新翠在WOT2023大会上的主题分享,更多精彩内容及现场PPT,请关注51CTO技术栈公众号,发消息【WOT2023PPT】即可直接领取
  • 这款新兴工具平台,让你的电脑效率翻倍

    随着信息技术的发展,我们获取信息的渠道越来越多,但是处理信息的效率却成为一个瓶颈。于是各种工具应运而生,都在争相解决我们的工作效率问题。今天我要给大家介绍一款效率
  • .NET 程序的 GDI 句柄泄露的再反思

    一、背景1. 讲故事上个月我写过一篇 如何洞察 C# 程序的 GDI 句柄泄露 文章,当时用的是 GDIView + WinDbg 把问题搞定,前者用来定位泄露资源,后者用来定位泄露代码,后面有朋友反
  • 8月见!小米MIX Fold 3获得3C认证:支持67W快充

    这段时间以来,包括三星、一加、荣耀等等有不少品牌旗下的最新折叠屏旗舰都得到了不少爆料,而小米新一代折叠屏旗舰——小米MIX Fold 3此前也屡屡被传
  • 2纳米决战2025

    集微网报道 从三强争霸到四雄逐鹿,2nm的厮杀声已然隐约传来。无论是老牌劲旅台积电、三星,还是誓言重回先进制程领先地位的英特尔,甚至初成立不久的新
  • Windows 11发布,微软一改往常对老机型开放的态度

    距离 Windows 11 发布已经过去一周,在过去一周里,很多数码爱好者围绕其对 Android 应用的支持、对老机型的升级问题展开了激烈讨论。与以往不同的是,在这次大
  • 联想小新Pad Pro 12.6将要推出,搭载高通骁龙 870 处理器

    联想小新Pad Pro 12.6将于秋季新品会上推出,官方按照惯例直接在发布会前给出了机型的所有参数。联想小新 Pad Pro 12.6 将搭载高通骁龙 870 处理器,重量为 5
Top