当前位置: 首页 > news >正文

用python实现单链表的基础操作

1 问题

用python实现单链表的基础操作:插入,删除,遍历,判空,清空链表,求长度,获取元素,判断元素是否存在。

2 方法

解决问题的步骤采用如下方式:

  1. 使用函数和类的方法来实现单链表的基本操作

  2. 插入操作时使用头插法

  3. 删除操作时,删除头节点一行代码即可,其他位置的需要判断+遍历

通过实验、实践等证明提出的方法是有效的,是能够解决开头提出的问题。

代码清单 1

class Node:
   """链表节点初始化"""
   def __init__(self, item):
       self.item = item
       self._next = None
class LinkList:
   """链表及其相关操作"""
   def __init__(self):
       self._head = None
   def is_empty(self):
       """判断是否为空链表,头节点为None则是空"""
       return self._head is None
   def length(self):
       """求链表的长度"""
       p = self._head
       count = 0
       while p:
           count += 1
           p = p._next
       return count
   def append(self, item):
       """向链表尾部添加元素, 考虑是否是空链表"""
       node = Node(item)
       p = self._head
       if not p:
           self._head = node
       else:
           while p._next:
               p = p._next
           p._next = node
   def add(self, item):
       """向链表头部插入元素"""
       node = Node(item)
       node._next = self._head
       self._head = node
   def insert(self, position, item):
       """向链表中插入元素"""
       # 头插 or 尾插 or 中间插入
       if position <= 0:
           self.add(item)
       elif position >= self.length():
           self.append(item)
       else:
           pre = self._head
           count = 0
           while count < position - 1:
               count += 1
               pre = pre._next
           node = Node(item)
           node._next = pre._next
           pre._next = node
   def get_item(self, position):
       """获取某位置的元素"""
       if position < 0 or position >= self.length():
           return None
       p = self._head
       count = 0
       while count != position:
           p = p._next
           count += 1
       return p.item
   def exixt_value(self, item):
       """某个值是否存在"""
       p = self._head
       while p:
           if p.item == item:
               return True
           else:
               p = p._next
       return False
   def remove(self, item):
       """删除元素"""
       p = self._head
       pre = None
       while p:
           if p.item == item:
               # 是否头节点
               if not pre:
                   self._head = p._next
               else:
                   pre._next = p._next
                   break
           else:
               pre = p
               p = p._next
   def clear(self):
       """删除链表"""
       self._head = None
   def travel(self):
       """列表遍历"""
       p = self._head
       while p:
           print(p.item, end=" ")
           p = p._next
       print()
if __name__ == '__main__':
   linklist = LinkList()
   linklist.append(2)
   linklist.append(3)
   linklist.append(4)
   linklist.append(5)
   print(linklist.length())  
   linklist.travel()  
   linklist.add(1)
   linklist.add(0)
   linklist.travel()  
   linklist.insert(2, 8)
   linklist.insert(2, 9)
   linklist.travel()  
   print(linklist.get_item(2), linklist.get_item(12), linklist.get_item(4))    
   print(linklist.exixt_value(9), linklist.exixt_value(20))    
   linklist.remove(9)
   linklist.remove(5)
   linklist.travel()  
   linklist.clear()
   linklist.travel()  

3 结语

针对用python实现单链表的基础操作,通过python运行实验,证明该方法是有效的,这种设置方法代码较多,因此未来还需继续改善这种方法以适应更多场景。

相关文章:

用python实现单链表的基础操作

1 问题 用python实现单链表的基础操作&#xff1a;插入&#xff0c;删除&#xff0c;遍历&#xff0c;判空&#xff0c;清空链表&#xff0c;求长度&#xff0c;获取元素&#xff0c;判断元素是否存在。 2 方法 解决问题的步骤采用如下方式&#xff1a; 使用函数和类的方法来实…...

[头歌系统数据库实验] 实验3 MySQL的DDL语言

目录 第1关&#xff1a;将P表中的所有红色零件的重量增加6 第2关&#xff1a;把P表中全部红色零件的颜色改成蓝色 第3关&#xff1a;将SPJ表中由S5供给J4的零件P6改为由S3供应 第4关&#xff1a;将SPJ表中所有天津供应商的QTY属性值减少11&#xff08;用子查询方式&#x…...

系统运维安全之病毒自检及防护

一、前言 Linux勒索病毒&#xff08;Linux ransomware&#xff09;是一种最令人恶心的计算机恶意病毒&#xff0c;它以侵入Linux系统&#xff0c;捆绑文件并要求支付赎金才能释放文件为主要目的&#xff0c;破坏用户的数据&#xff0c;造成数据讹诈。Linux勒索病毒它们的存在已…...

Mabatis处理异常屏蔽SQL返回前端全局异常捕获处理

文章目录 Mabatis处理异常屏蔽SQL返回前端全局异常捕获处理结论1 java异常体系2 Spring框架异常处理3 定位Spring框架转化为哪种unchecked异常3.1 捕获RuntimeException定位Spring框架转化抛出的异常类3.2 进一步查看包名判断3.3 识别MyBatisSystemException下级实现3.3 识别My…...

黑豹程序员-java发邮件,发送内容支持html,带多附件的案例

介绍 发邮件mail是常见的软件功能&#xff0c;下面利于spring和java的mail库实现发送内容支持html&#xff0c;带多附件的案例 开启SMTP邮件发送协议 谁提供的SMTP邮件服务&#xff0c;就找谁开启。QQ邮箱类似。 依赖 <!--Java MAil 发送邮件API--><dependency&g…...

[LeetCode] 15. 三数之和

15. 三数之和 给你一个整数数组 nums &#xff0c;判断是否存在三元组 [nums[i], nums[j], nums[k]] 满足 i ! j、i ! k 且 j ! k &#xff0c;同时还满足 nums[i] nums[j] nums[k] 0 。请 你返回所有和为 0 且不重复的三元组。 **注意&#xff1a;**答案中不可以包含重复…...

Android Chips(标签)

目录 一、流式布局标签发展历程 二、类型及使用 2.1 Chip.Action(默认值) 2.2 Chip.Entry 2.3 Chip.Filter 2.4 Chip.Choice 三、常用事件 3.1 OnClickListener 3.2 OnCheckedChangeListener 3.3 OnCloseIconClickListener 四、ChipGroup 4.1 ChipGroup Chip.Choi…...

飞行汽车开发原理(上)

前言 小节的安排是由浅入深&#xff0c;要按顺序读&#xff1b;有电路知识基础的同学可跳到“计算机电路”一节开始。因为知识点之间有网状依赖&#xff0c;没办法按分类来讲。 为了避免过于深入、越讲越懵&#xff0c;很多描述仅为方便理解、不求严谨。 半导体特性 导体&a…...

22、pytest多个参数化的组合

官方实例 # content of test_multi_parametrie.py import pytestpytest.mark.parametrize("x",[0,1]) pytest.mark.parametrize("y",[2,3]) def test_foo(x,y):print("{}-{}".format(x,y))pass解读与实操 要获得多个参数化参数的所有组合&…...

【网络奇缘】- 如何自己动手做一个五类|以太网|RJ45|网络电缆

​ ​ &#x1f308;个人主页: Aileen_0v0&#x1f525;系列专栏: 一见倾心,再见倾城 --- 计算机网络~&#x1f4ab;个人格言:"没有罗马,那就自己创造罗马~" 本篇文章关于计算机网络的动手小实验---如何自己动手做一个网线&#xff0c; 也是为后面的物理层学习进…...

【从零开始学习JVM | 第三篇】类的生命周期(高频面试)

前言&#xff1a; 在Java编程中&#xff0c;类的生命周期是指类从被加载到内存中开始&#xff0c;到被卸载出内存为止的整个过程。了解类的生命周期对于理解Java程序的运行机制以及性能优化非常重要。 在本文中&#xff0c;我们将深入探讨类的生命周期&#xff0c;从类加载到…...

详解前后端交互时PO,DTO,VO模型类的应用场景

前后端交互时的数据传输模型 前后端交互流程 前后端交互的流程: 前端与后端开发人员之间主要依据接口进行开发 前端通过Http协议请求后端服务提供的接口后端服务的控制层Controller接收前端的请求Contorller层调用Service层进行业务处理Service层调用Dao持久层对数据持久化 …...

力扣295. 数据流的中位数

优先队列 思路&#xff1a; 中位数是排序中间的数值&#xff1a;S1.M.S2可以使用两个优先队列来存放两边的数值&#xff0c;总是使得左侧的堆顶是最大的&#xff0c;右侧的堆顶是最小的&#xff0c;即使用大顶堆存放 S1&#xff0c;使用小顶堆存放S2&#xff0c;使得两个队列的…...

英语二笔记

完型填空 20题/0.5分 总分10, 至少拿8分 阅读理解A 20题/2分 总分40 至少拿24分 阅读理解B 5题/2分 总分10 至少拿6分 短文翻译 1题/15分 …...

【OpenSSH升级】升级后证书认证登录突然失效

上一篇“【OpenSSH升级】无论密码输入正确与否总是登录失败&#xff08;error: Could not get shadow information for root&#xff09;”总结了CentOS7上的openssh从7.4升级到9.4之后&#xff0c;密码认证失败问题&#xff0c;这里再总结一下证书认证失效问题。 大多数情况下…...

pytest +uiautomator2+weditor app自动化从零开始

目录结构1.0 把设备连接单独移出去了 模块操作代码&#xff0c;有一些流程操作和断言方法 from devices import dv from time import sleep import random from tool.jt import capture_screenshotdef initialization(func):def wrapper():sleep(1)dv.app_stop(com.visteon.…...

【计算机网络笔记】物理层——信道与信道容量

系列文章目录 什么是计算机网络&#xff1f; 什么是网络协议&#xff1f; 计算机网络的结构 数据交换之电路交换 数据交换之报文交换和分组交换 分组交换 vs 电路交换 计算机网络性能&#xff08;1&#xff09;——速率、带宽、延迟 计算机网络性能&#xff08;2&#xff09;…...

深度学习火车票识别系统 计算机竞赛

文章目录 0 前言1 课题意义课题难点&#xff1a; 2 实现方法2.1 图像预处理2.2 字符分割2.3 字符识别部分实现代码 3 实现效果4 最后 0 前言 &#x1f525; 优质竞赛项目系列&#xff0c;今天要分享的是 &#x1f6a9; 图像识别 火车票识别系统 该项目较为新颖&#xff0c;适…...

C++EasyX之井字棋

视频链接 井字棋 用EasyX和C实现井字棋小游戏 源码及注释 #include<graphics.h>char board_data[3][3] {{-,-,-},{-,-,-},{-,-,-}, };char current_piece O;//检测指定棋子的玩家是否获胜 bool CheckWin(char c) {// 检查每一行for (int i 0; i < 3; i){if (bo…...

12.5_黑马数据结构与算法Java

目录 001 二分查找 算法描述 002 二分查找 算法实现 003 二分查找 问题1 循环条件 004 二分查找 问题2 中间索引 thinking&#xff1a;反码补码原码&#xff1f; thinking&#xff1a;二进制转十进制&#xff1f; thinking&#xff1a;无符号右移&#xff1f; 005 二分…...

NCM音乐解锁终极指南:3分钟掌握免费快速解密转换工具

NCM音乐解锁终极指南&#xff1a;3分钟掌握免费快速解密转换工具 【免费下载链接】ncmppGui 一个使用C编写的极速ncm转换GUI工具 项目地址: https://gitcode.com/gh_mirrors/nc/ncmppGui 你是否曾经遇到过这样的情况&#xff1a;从音乐平台下载了心爱的歌曲&#xff0c;…...

构建企业的知识图谱

在智能制造与大模型时代&#xff0c;构建制造企业的工业知识图谱&#xff08;Industrial Knowledge Graph, IKG&#xff09;&#xff0c;是将企业沉淀在老师傅头脑中、纸面技术手册、PLM图纸以及MES日志中的“隐性知识”&#xff0c;转化为 AI 和工业智能体&#xff08;Industr…...

d2s-editor:暗黑破坏神2存档修改终极实战宝典

d2s-editor&#xff1a;暗黑破坏神2存档修改终极实战宝典 【免费下载链接】d2s-editor 项目地址: https://gitcode.com/gh_mirrors/d2/d2s-editor 还在为暗黑破坏神2的刷装备、练级、属性点分配而烦恼吗&#xff1f;d2s-editor为你带来全新的单机游戏体验——这是一款基…...

Unet学习笔记1——全矩阵运算理解5种核心操作(傻瓜版)

Unet学习笔记1——全矩阵运算理解5种核心操作&#xff08;傻瓜版&#xff09; 文章目录Unet学习笔记1——全矩阵运算理解5种核心操作&#xff08;傻瓜版&#xff09;一、unet模型干了什么二、宏观架构&#xff1a;“U”型流水线的三个核心乐章三、看懂图纸上的 5 种核心操作&am…...

动态路由协议与BGP路径属性:网络工程师的核心必修课

1. 从“路标”到“地图”&#xff1a;动态路由协议的核心价值 在网络世界里&#xff0c;路由器就像一个个十字路口的交通警察。如果每个路口都需要手动设置去往所有目的地的路牌&#xff0c;那不仅工作量巨大&#xff0c;一旦某条路临时施工或封闭&#xff0c;整个城市的交通都…...

基于ReAct范式的链式追踪工具:提升学术研究效率的AI智能体实践

1. 项目概述与核心价值如果你经常需要做文献调研、追踪某个科学概念的源头&#xff0c;或者想搞清楚一个复杂话题背后的证据链&#xff0c;那你一定体会过在搜索引擎和无数个学术网站之间反复横跳的痛苦。传统的搜索方式&#xff0c;比如在Google Scholar里输入一个关键词&…...

避坑指南:组态王7.5报表脚本中那些容易出错的细节(日报月报年报)

组态王7.5报表脚本深度排错手册&#xff1a;从日报到年报的实战避坑指南 在工业自动化系统中&#xff0c;数据报表的准确性和稳定性直接关系到生产管理的可靠性。组态王7.5作为广泛使用的SCADA软件&#xff0c;其报表功能在实际应用中却常常因为脚本细节问题导致数据异常、文件…...

如何在5分钟内掌握BilibiliDown:B站视频下载神器完整使用指南

如何在5分钟内掌握BilibiliDown&#xff1a;B站视频下载神器完整使用指南 【免费下载链接】BilibiliDown (GUI-多平台支持) B站 哔哩哔哩 视频下载器。支持稍后再看、收藏夹、UP主视频批量下载|Bilibili Video Downloader &#x1f633; 项目地址: https://gitcode.com/gh_mi…...

WechatSogou微信公众号爬虫实战指南:高效获取公众号数据的Python解决方案

WechatSogou微信公众号爬虫实战指南&#xff1a;高效获取公众号数据的Python解决方案 【免费下载链接】WechatSogou 基于搜狗微信搜索的微信公众号爬虫接口 项目地址: https://gitcode.com/gh_mirrors/we/WechatSogou 在信息爆炸的时代&#xff0c;微信公众号已成为内容…...

React应用部署实战:Nginx配置与性能调优

1. React应用部署前的准备工作 第一次部署React应用到生产环境时&#xff0c;我踩过不少坑。记得有个项目上线后&#xff0c;用户反馈页面加载特别慢&#xff0c;排查后发现是静态资源没有做任何优化。从那以后&#xff0c;我养成了部署前必须做好三项准备工作的习惯。 首先是项…...