Python数据结构之单向链表和双向链表

2024-05-04 07:38

本文主要是介绍Python数据结构之单向链表和双向链表,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

链表的定义:

链表是通过一个个节点(Node)组成的,每个节点都包含了称为数据域(data)和指针域(next)的基本单元,它也是一种递归的数据结构。它能保持数据之间的逻辑顺序,但存储空间不必按照顺序存储。

链表的操作

  • is_empty() 链表是否为空
  • length() 链表长度即节点个数
  • travel() 遍历链表
  • add(item) 链表头部添加节点
  • append(item) 链表尾部添加节点
  • insert(index, item) 指定位置添加节点
  • remove(item) 删除节点
  • search(item) 查找节点是否存在

python实现代码

#!/usr/bin/env python3
# coding=utf-8class Node(object):"""节点"""def __init__(self, temp_data):super(Node, self).__init__()self.data = temp_dataself.prev = Noneself.next = None class SingleLinkList(object):"""单向链表"""def __init__(self, temp_node=None):super(SingleLinkList, self).__init__()self.head = temp_nodedef is_empty(self):"""链表是否为空"""return not self.head def length(self):"""链表长度(节点个数)"""cur = self.headcount = 0while cur:count += 1cur = cur.nextreturn count def travel(self):"""遍历链表"""cur = self.headwhile cur:print(cur.data, end=" ")cur = cur.nextprint()def add(self, item):"""链表头部添加元素"""node = Node(item)node.next = self.headself.head = node def append(self, item):"""链表尾部添加元素"""node = Node(item)cur = self.headif self.is_empty():self.head = nodeelse:while cur.next:cur = cur.nextcur.next = node def insert(self, index, item):"""指定位置添加元素"""if index <= 0:self.add(item)elif index > self.length()-1:self.append(item)else:node = Node(item)cur = self.headfor i in range(index-1):cur = cur.nextnode.next = cur.nextcur.next = node def remove(self, item):"""删除节点"""cur = self.headpre = None while cur:if cur.data == item:if cur == self.head:self.head = cur.nextbreakelse:pre.next = cur.nextbreak pre = cur cur = cur.next def search(self, item):"""查找节点是否存在"""cur = self.headwhile cur:if cur.data == item:return Truecur = cur.nextreturn False class DoubleLinkList(SingleLinkList):"""双向链表"""def add(self, item):"""从链表头部插入节点"""node = Node(item)if self.is_empty():self.head = nodeelse:node.next = self.headnode.next.prev = node self.head = node def append(self, item):"""从链表尾部插入节点"""node = Node(item)if self.is_empty():self.head = nodeelse:cur = self.headwhile cur.next:cur = cur.nextcur.next = nodenode.prev = cur def insert(self, index, item):"""从指定位置插入节点"""if index <= 0:self.add(item)elif index > self.length()-1:self.append(item)else:node = Node(item)cur = self.headfor i in range(index-1):cur = cur.nextnode.next = cur.nextcur.next.prev = nodenode.prev = curcur.next = nodedef remove(self, item):"""删除节点"""cur = self.headwhile cur:if cur.data == item:if cur == self.head: self.head = cur.nextif cur.next:cur.next.prev = cur.prev  else:cur.prev.next = cur.nextif cur.next:cur.next.prev = cur.prev break else:cur = cur.next if __name__ == "__main__":my_list = SingleLinkList()#my_list = DoubleLinkList()for i in range(10):my_list.append(i)print(my_list.length())my_list.travel()my_list.insert(0, -6)my_list.travel()my_list.insert(6, 66)my_list.travel()my_list.insert(81, 666)my_list.travel()print(my_list.search(33))print(my_list.search(66))my_list.remove(66)my_list.travel()my_list.remove(-6)my_list.travel()my_list.remove(666)my_list.travel()

 

这篇关于Python数据结构之单向链表和双向链表的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/958676

相关文章

Zen of Python -Python之禅

在浏览Python官方文档时无意发现了这个彩蛋,只需在终端中import this The Zen of Python, by Tim PetersBeautiful is better than ugly.Explicit is better than implicit.Simple is better than complex.Complex is better than compli

Python内置函数oct()详解

Python中的oct()函数是一个内置函数,用于将一个整数转换成它的八进制字符串表示。 函数定义 oct()函数的基本语法如下: oct(x) x:一个整数。 函数返回x的八进制表示,以字符串形式。 基本用法 将整数转换为八进制 number = 64print(oct(number)) # 输出: '0o100' 转换负整数 number = -64print(o

Python筑基之旅-溯源及发展

目录 一、Python的起源 二、Python的版本更替及变化 三、Python的优缺点 四、Python的发展方向 五、Python之禅 六、推荐专栏/主页: 1、Python函数之旅:Functions 2、Python算法之旅:Algorithms 3、个人主页:https://myelsa1024.blog.csdn.net/ ​​​​​​​ 一、Python

Python专题:十六、异常处理(2)

异常的预判和防护 import randomnum = random.randint(1, 100) # 获得一个随机数is_done = False # 是否猜中的标记count = 0 # 玩家猜了几次while not is_done:guess = int(input('请输入一个[1, 100]的整数:'))if guess == num:is_done = Trueelif

2024年05月16日【链表学习笔记】

以下是一些与链表概念相关的问题,这些问题可以帮助你评估自己对链表的理解: 1.基本概念 1.什么是链表? 一种线性表数据结构,这种数据结构使用一组人意的存储单元,,用于存储同类型的数据元素 2.链表与数组有什么区别? 链表和数组是两种常见的数据结构,它们在存储方式和操作特性上有着本质的不同: 存储方式: 数组:在内存中连续存储,每个元素的位置是固定的。数组的大小在创建时就已确定,如果

理解 Python 中的 `super()` 与 `__init__()` 方法

在 Python 的面向对象编程中,super() 函数和 __init__() 方法是两个非常重要的概念。它们在类的继承和初始化过程中扮演着关键的角色。本文将深入探讨这两个概念的工作原理,并通过示例代码来展示它们的使用。 基本原理 __init__() 方法 __init__() 是一个特殊的方法,也称为类的构造器。当你创建一个类的新实例时,Python 会自动调用这个方法。它通常用于初始

python 合并 pdf

from pypdf import PdfMergerpdfs = ['file1.pdf', 'file2.pdf', 'file3.pdf', 'file4.pdf']merger = PdfMerger()for pdf in pdfs:merger.append(pdf)merger.write("result.pdf")merger.close() 参考 https://stack

Python——IO编程

IO在计算机中指Input/Output,也就是输入和输出。由于程序和运行时数据是在内存中驻留,由CPU这个超快的计算核心来执行,涉及到数据交换的地方,通常是磁盘、网络等,就需要IO接口。 比如你打开浏览器,访问新浪首页,浏览器这个程序就需要通过网络IO获取新浪的网页。浏览器首先会发送数据给新浪服务器,告诉它我想要首页的HTML,这个动作是往外发数据,叫Output,随后新浪服务器把网页发过来,

python 脚本压缩文件linux 正常,windows 文件夹/文件名称 被加上了上级文件夹名

场景: php 在调用python 脚本,进行文件压缩(因为php的压缩大文件总是超时),linux/mac 环境文件/文件夹名压缩前后一致,windows 压缩后 文件/文件夹名被改变为 上级 文件夹+原名 原因: windows 和 mac、linux 文件路径的分隔符 不一样 解决: 使用php 自带的分隔符常量DIRECTORY_SEPARATOR,该常量会根据 不同系统,变化

Python简易图书管理系统重构

在本篇课文中,我们将使用Python语言结合MySQL数据库,从零开始构建一个简单的图书管理系统。该系统旨在帮助图书馆管理员轻松管理图书的借阅、归还以及查询图书信息等日常操作。我们将分步介绍需求分析、数据库设计、环境搭建、功能实现等关键环节,并提供详细的源代码示例。 #### **一、需求分析** 图书管理系统的核心功能包括: - 图书录入:允许管理员添加新书到系统。 - 图书查询:提供按书名