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

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

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

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

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

1.链表的基本概念

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

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

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

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

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

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

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

2.向链表中添加元素

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

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

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

小结

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

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

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

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

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

标签:
  • 热门焦点
  • MIX Fold3包装盒泄露 新机本月登场

    小米的全新折叠屏旗舰MIX Fold3将于本月发布,近日该机的真机包装盒在网上泄露。从图上来看,新的MIX Fold3包装盒在外观设计方面延续了之前的方案,变化不大,这也是目前小米旗舰
  • 6月安卓手机性能榜:vivo/iQOO霸占旗舰排行榜前三

    2023年上半年已经正式过去了,我们也迎来了安兔兔V10版本,在新的骁龙8Gen3和天玑9300发布之前,性能榜的榜单大体会以骁龙8Gen2和天玑9200+为主,至于那颗3.36GHz的骁龙8Gen2领先
  • 28个SpringBoot项目中常用注解,日常开发、求职面试不再懵圈

    前言在使用SpringBoot开发中或者在求职面试中都会使用到很多注解或者问到注解相关的知识。本文主要对一些常用的注解进行了总结,同时也会举出具体例子,供大家学习和参考。注解
  • CSS单标签实现转转logo

    转转品牌升级后更新了全新的Logo,今天我们用纯CSS来实现转转的新Logo,为了有一定的挑战性,这里我们只使用一个标签实现,将最大化的使用CSS能力完成Logo的绘制与动画效果。新logo
  • 每天一道面试题-CPU伪共享

    前言:了不起:又到了每天一到面试题的时候了!学弟,最近学习的怎么样啊 了不起学弟:最近学习的还不错,每天都在学习,每天都在进步! 了不起:那你最近学习的什么呢? 了不起学弟:最近在学习C
  • 2023年,我眼中的字节跳动

    此时此刻(2023年7月),字节跳动从未上市,也从未公布过任何官方的上市计划;但是这并不妨碍它成为中国最受关注的互联网公司之一。从2016-17年的抖音强势崛起,到2018年的“头腾
  • 2天涨粉255万,又一赛道在抖音爆火

    来源:运营研究社作者 | 张知白编辑 | 杨佩汶设计 | 晏谈梦洁这个暑期,旅游赛道彻底火了:有的「地方」火了——贵州村超旅游收入 1 个月超过 12 亿;有的「博主」火了&m
  • 小米公益基金会捐赠2500万元驰援北京、河北暴雨救灾

    8月2日消息,今日小米科技创始人雷军在其微博上发布消息称,小米公益基金会宣布捐赠2500万元驰援北京、河北暴雨救灾。携手抗灾,京冀安康!以下为公告原文
  • 华为发布HarmonyOS 4:更好玩、更流畅、更安全

    在8月4日的华为开发者大会2023(HDC.Together)大会上,HarmonyOS 4正式发布。自2019年发布以来,HarmonyOS一直以用户为中心,经历四年多的发展HarmonyOS已
Top