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

数据结构与算法-(10)---列表(List)

 

 🌈write in front🌈
🧸大家好,我是Aileen🧸.希望你看完之后,能对你有所帮助,不足请指正!共同学习交流.
🆔本文由Aileen_0v0🧸 原创 CSDN首发🐒 如需转载还请通知⚠️
📝个人主页:Aileen_0v0🧸—CSDN博客
🎁欢迎各位→点赞👍 + 收藏⭐️ + 留言📝​
📣系列专栏:Aileen_0v0🧸的PYTHON学习系列专栏——CSDN博客
🗼我的格言:"没有罗马,那就自己创造罗马~" 

目录

列表(List) 

采用链表实现无序表

无序表(元素之间没有顺序,但是有位置顺序)

列表 

链表  

链表的实现 

 Unordered List - 无序表

Add方法

size方法 

 remove(item)方法


 

列表(List) 

列表是Python中的一种数据类型,用于存储一组有序的数据。列表中可以存储任意类型的数据,包括数字、字符串、布尔值等。列表以中括号 [ ] 表示,其中的每个元素之间用逗号分隔,例如:

my_list = [1, 2, 3, 4, 5]

上述代码创建了一个名为 my_list 的列表,其中包含了整数 1、2、3、4 和 5。可以使用索引访问列表中的元素,例如 my_list[0] 访问列表中的第一个元素。列表支持许多常用的操作,如添加元素、删除元素、排序等。

但并不是所有的编程语言都提供了List数据类型有时候需要程序员自己实现。

列表:是一种数据项按照相对位置存放的数据集

特别的,被称为“无序表unordered list”其中数据项只按照存放位置来索引,如第1个、第2个....."、最后一个等。(为了简单起见,假设表中不存在重复数据项)

如一个考试分数的集合“54,26,93,1777和31”

如果用无序表来表示,就是[54,26,9317, 77, 31]

采用链表实现无序表

采用链表实现无序表的主要原因是,链表有动态性和灵活性。当我们需求插入或删除元素时,链表可以快速地进行操作,而不需要进行大量的数据移动。此外,链表还可以通过动态分配内存空间来适应数据的变化,这使得无序表可以处理不同大小的数据集

另外,链表实现无序表还有以下优点:

  1. 内存使用效率高:链表只需要分配和使用存储空间,而不需要事先设置固定的存储大小,这可以节省内存空间。

  2. 适用于大型数据集:链表可以处理大量的数据,因为它们不需要在内存中保持连续的存储空间,而是可以分散在内存中的不同区域。

  3. 可以有效地处理插入和删除操作:链表的插入和删除操作很快,因为它们只需要修改指针,而不需要移动元素。

链表是一种非常适合实现无序表的数据结构,因为它具有动态性,灵活性,高效性和内存使用效率高等优点。

无序表(元素之间没有顺序,但是有位置顺序)

列表 

Python 中往列表添加数据,不能灵活添加,因为列表不具有连续的空间

所以元素4不能添加到列表里.


链表  

由于链表( Linked List )含 pointer(指针) 所以链表可以利用碎片化空间将数据传入到空格处,

即使被其它元素占领了内存空间 

# 通过链表实现 无序表-列表
#列表 和 链表 都是无序表 unordered list
#实现链表
class Node:def __init__(self,init_data):self.data = init_dataself.next = None#获得数据项def get_data(self):return self.data#获得节点def get_next(self):return self.next#设置数据项def set_data(self,new_data):self.data = new_data#设置节点def set_next(self,new_next):self.next = new_next#结点示例
temp = Node(93)
print(temp.get_data())

链表的实现 

可以采用 链接结点 的方式来构建数据集 实现无序表

链表的第一个最后一个 节点最重要 

如果想访问到链表中的所有节点,就必须从第一个节点沿链接遍历下去.

 

 Unordered List - 无序表

箭头所指为表头

最快捷的就是从表头开始(相当于insert[0]),

但是之前列表实现inser[0]的时间复杂度是O(n),

链表是O(1)

结点(node): 为了组织链表引入的一个结构,除了保存我们的元素之外,还会保存指向下一个结点的引用 

当前结点(current / cur): 表示链表中某个结点
前驱结点(previous / prev): 表示链表中某个结点的前一个结点头结点没有前驱结点
后继结点(next): 表示链表某个结点的后一个结点尾结点没有后继结点

链表的头结点, 链表最开始的节点~
尤其是对单链表来说, 只要知道了链表的头结点可以获取到链表的所有的元素
通常情况下,特别喜欢用头结点来代指整个链表~

Add方法

思路步骤如下:

    #为item数据项生成一个结点-Node 叫做itemdef add(self,item):#然后将这个结点命名为临时变量temp = Node(item)#将下一个临时结点设置为表头temp.set_next(self.head)#表头指向新增加的临时结点self.head = temp

注意:第三第四行代码顺序不能调换,否则会发生链表丢失

size方法 

    def size(self):#当前节点设为表头第一个节点current = self.headcount = 0while current != None:count += 1#将当前节点设为下一个结点的结点,循环往复current = current.get_next()#返回结点的个数return count

 

    def search(self,item):current = self.headfound = Falsewhile current != None and not found:#判断当前节点数据项是否等于我想要找的数据if current.getData() == item:found = Trueelse:current = current.get_next()return found

 remove(item)方法

 

    def remove(self,item):current = self.headprevious = Nonefound = Falsewhile not found:if current.get_data == item:found = Trueelse:previous = currentcurrent = current.get_nextif previous == None:self.head = current.get_next()else:previous.set_next(current.get_next())

 

相关文章:

数据结构与算法-(10)---列表(List)

🌈write in front🌈 🧸大家好,我是Aileen🧸.希望你看完之后,能对你有所帮助,不足请指正!共同学习交流. 🆔本文由Aileen_0v0🧸 原创 CSDN首发🐒 如…...

Node-Web模块的用法

题记 node.js中web模块的用法,以下是具体操作过程和代码。 Web服务器一般指网站服务器,是指驻留于因特网上某种类型计算机的程序,Web服务器的基本功能就是提供Web信息浏览服务。它只需支持HTTP协议、HTML文档格式及URL,与客户端的…...

基于TCP的RPC服务

TCP服务器上的RPC,通过创建一个服务器进程监听传入的tcp连接,并允许用户 通过此TCP流执行RPC命令 -module(tr_server). -author("chen"). -behaviour(gen_server).%% API -export([start_link/1,start_link/0,get_count/0,stop/0 ]).-export(…...

docker报错问题解决:Error Invalid or corrupt jarfile app.jar

文章目录 1.问题描述2.问题分析3.问题解决 1.问题描述 此时处在 /home/ubuntu/app 目录下,并且在该目录下有一个 jenkins-0.0.1-SNAPSHOT.jar。 我在 /home/ubuntu/app 目录下执行了 docker 容器运行命令: # 映射 8859 端口 # 容器名为 jenkins-demo #…...

Day 09 python学习笔记

函数 装饰器 回顾内容: 函数可以作为参数进行传递函数可以作为返回值函数名称可以像变量一样进行赋值操作 装饰器:要求记住结论 引入: def play_dnf():print("你好啊,我是赛利亚,今天又是美好的一天")def p…...

力扣labuladong——一刷day02

提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档 文章目录 前言一、力扣876. 链表的中间结点二、力扣142. 环形链表 II三、力扣160. 相交链表四、力扣141. 环形链表 前言 一、力扣876. 链表的中间结点 /*** Definition for …...

【小白专用23.10.22 已验证】windows 11 安装PHP8.2 +Apache2.4

环境说明 windows:windows 11 x64apache: Apache/2.4.43php :php-8.2.11 一.php 1、PHP下载 PHP For Windows: Binaries and sources Releases 注意: 1.要下载Thread Safe,否则没有php8apache2_4.dll这个文件;如果使用Apache作为服务器…...

Nmap端口服务 之 CentOS7 关于启动Apache(httpd)服务、telnet服务、smtp服务、ftp服务、sftp服务

Nmap端口服务 之 CentOS7 关于启动Apache(httpd)服务、telnet服务、smtp服务、ftp服务、sftp服务 一. CentOS7 安装配置SFTP服务器详解一、SFTP简介二、关闭防火墙三、安装SSH服务在CentOS7中,sftp只是ssh的一部分,所以采用yum来安装ssh服务即可1. 查看是否已经安装了ssh2.…...

为什么 glBegin 未被定义 未定义的标识符,使用新的 API(LearnOpenGL P2)

文章目录 弃用的 glBegin & glEnd使用新 API 的示例 弃用的 glBegin & glEnd 环境:glfw 3.3.8 glad core OpenGL 初学者在尝试使用 glBegin 和 glEnd 函数来绘制三角形时,有可能找到使用这些函数的文章、代码文献 但许多这些函数已经在OpenG…...

C++多态、虚函数、纯虚函数、抽象类

多态的概念 通俗来说,就是多种形态,具体点就是去完成某个行为,当不同的对象去完成时会产生出不同的状态。 举个简单的例子:抢红包,我们每个人都只需要点击一下红包,就会抢到金额。有些人能…...

20231019_vue学习

引入vue.js: <script src"https://cdn.staticfile.org/vue/2.2.2/vue.min.js"></script> vue.js <script src"https://cdn.staticfile.org/vue-router/2.7.0/vue-router.min.js"></script> 路由vue模板语法 v-html:添加html模板…...

熟练使用 Redis 的五大数据结构:Java 实战教程

入门 入门阶段主要记住 Redis 的命令&#xff0c;熟练使用 Redis 的 5 大数据结构就可以了。 如果没有 Redis 环境&#xff0c;可以直接通过这个网址https://try.redis.io/&#xff0c;很赞&#xff0c;它会给你模拟一个在线的环境可供你尽情使用&#xff01; 熟练使用Redis的…...

【Linux】kill 命令使用

经常用kill -9 XXX 。一直在kill&#xff0c;除了kill -9 -15 &#xff0c;还能做什么&#xff1f;今天咱们一起学习一下。 kill 命令用于删除执行中的程序或工作。 kill命令 -Linux手册页 命令选项及作用 执行令 man kill 执行命令结果 参数 -l 信号&#xff0c;若果…...

面试-Redis-缓存雪崩

问&#xff1a;什么是缓存雪崩 ? 答&#xff1a;缓存过期是指设置缓存时都采用了同一过期时间&#xff0c;导致缓存在莫一时刻同时失效&#xff0c;从而请求全部全部打到数据库中&#xff0c;导致数据库压力过大而挂机。 它与缓存击穿的区别是&#xff1a;缓存击穿是一个key…...

AI全栈大模型工程师(九)Function Calling 的机制

文章目录 Function Calling 的机制Function Calling 示例 1:加法计算器Function Calling 实例 2:四则混合运算计算器后记Function Calling 的机制 Function Calling 示例 1:加法计算器 需求:用户输入任意可以用加法解决的问题,都能得到计算结果。 # 加载环境变量import o…...

音乐制作软件 Ableton Live 11 Suite mac中文版功能介绍

Ableton Live 11 Suite mac是一款专业级别的音乐制作软件&#xff0c;它提供了多种音乐制作和编辑功能&#xff0c;可以帮助用户创建各种音乐作品。界面简单直观&#xff0c;可以方便地进行各种音乐制作操作。它提供了丰富的音乐制作工具和功能&#xff0c;如录音、采样、编曲、…...

v-model和.sync区别

在vue2中提供了.sync修饰符&#xff0c;但是在vue3中不再支持.sync&#xff0c;取而代之的是v-model。 1.在vue2中v-model和.sync区别&#xff1a; 1.相同点&#xff1a;都是语法糖&#xff0c;都可以实现父子组件中的数据的双向通信。 ​ 区别在于往回传值的时候. sync 的 $…...

django cloudflare csrf 403

网站套了cloudflare flare发现登录接口403了&#xff0c;csrf验证失败&#xff0c; debug设置为False 详细报错如下&#xff1a; Reason given for failure: Referer checking failed - https://xxx/login does not match any trusted origins.In general, this can occur w…...

Hive 中级练习题(40题 待更新)

前言 最近快一周没更了&#xff0c;主要原因是最近在忙另一件事情&#xff08;关于JavaFX桌面软件开发&#xff09;&#xff0c;眼看大三上一半时间就要过去了&#xff0c;抓紧先学Hive&#xff0c;完了把 Spark 剩下的补了&#xff0c;还有 Kafka、Flume&#xff0c;任务还是…...

核酸检测人员安排

题目描述: 在系统、网络均正常的情况下组织核酸采样员和志愿者对人群进行核酸检测筛查。每名采样员的效率不同,采样效率为N人/小时。由于外界变化,采样员的效率会以M人/小时为粒度发生变化,M为采样效率浮动粒度,M=N10%,输入保证N10%的结果为整数。采样员效率浮动规则:采…...

BKS势函数详解:从石英玻璃到LAMMPS模拟,你的二氧化硅参数选对了吗?

BKS势函数深度解析&#xff1a;二氧化硅模拟中的参数选择与实战指南 在分子动力学模拟领域&#xff0c;势函数的选择往往决定了整个研究的成败。对于二氧化硅(SiO₂)这种在自然界和工业应用中无处不在的材料&#xff0c;BKS(Buckingham-Coulomb)势函数因其出色的平衡性和广泛的…...

卫星通信工程师避坑指南:LNA放错位置,系统噪声温度飙升6倍!

卫星通信系统噪声温度优化实战&#xff1a;LNA布局错误引发的6倍性能灾难 当我在调试某型号卫星地面站时&#xff0c;发现接收灵敏度始终无法达到设计指标。经过三天三夜的排查&#xff0c;最终发现问题出在一个看似微不足道的细节——低噪声放大器&#xff08;LNA&#xff09;…...

不止美化:用OhMyPosh和Windows Terminal打造你的高效开发工作流

不止美化&#xff1a;用OhMyPosh和Windows Terminal打造你的高效开发工作流 每次打开终端&#xff0c;你是否也厌倦了那个灰暗单调的默认界面&#xff1f;作为一名开发者&#xff0c;我们每天有超过60%的时间都在与命令行打交道。一个精心配置的终端环境&#xff0c;绝不仅仅是…...

仅限Tier1供应商内部流传的Docker车载部署Checklist(v4.3),含17项ASAM OpenX标准兼容性校验项,免费领取最后47份

第一章&#xff1a;Docker车载部署优化在智能网联汽车边缘计算场景中&#xff0c;Docker 容器因轻量、可移植和快速启停等特性被广泛用于车载应用部署。然而&#xff0c;车载环境存在资源受限&#xff08;如 CPU/内存波动、存储空间紧张&#xff09;、网络不稳定、实时性要求高…...

【2026 Blazor生产环境黄金标准】:微软MVP亲测的11项安全加固清单(含OWASP Top 10 Blazor专项对策)

第一章&#xff1a;Blazor 2026生产环境安全治理全景图Blazor 2026 在企业级生产环境中已全面支持零信任架构&#xff08;ZTA&#xff09;与运行时策略即代码&#xff08;Policy-as-Code&#xff09;&#xff0c;其安全治理不再依赖单一防护层&#xff0c;而是贯穿于组件生命周…...

别再纠结Flannel和Calico了!手把手教你根据业务场景选对K8s网络插件

别再纠结Flannel和Calico了&#xff01;手把手教你根据业务场景选对K8s网络插件 当你在Kubernetes生产环境中面临网络插件选择时&#xff0c;Flannel和Calico这两个名字总会反复出现。就像站在十字路口的旅行者&#xff0c;左边是平坦快捷的柏油马路&#xff0c;右边是功能丰富…...

为什么你客户越多,业绩反而越差?

你有没有遇到过这种情况&#xff1a;市场说&#xff1a;今年线索翻倍了销售说&#xff1a;每天忙到飞起老板看报表&#xff1a;客户数越来越多但月底一看—— 业绩没涨&#xff0c;甚至还在掉。很多人第一反应是&#xff1a; 是不是销售不行&#xff1f;是不是产品不行&#xf…...

视觉SLAM实战指南:如何利用EuRoC MAV数据集进行算法验证与调优

1. 初识EuRoC MAV数据集&#xff1a;SLAM开发者的宝藏库 第一次接触EuRoC数据集时&#xff0c;我正为一个无人机项目调试视觉惯性里程计&#xff08;VIO&#xff09;算法。当时试过自己采集数据&#xff0c;结果发现标定误差和同步问题让调试过程变成噩梦。直到同事扔给我MH_01…...

手把手教你解决Sophus安装中的std::optional错误(Ubuntu20.04环境)

手把手教你解决Sophus安装中的std::optional错误&#xff08;Ubuntu20.04环境&#xff09; 如果你正在Ubuntu 20.04上搭建SLAM开发环境&#xff0c;安装Sophus库时遇到std::optional未声明的编译错误&#xff0c;这篇文章将为你提供一套完整的解决方案。这个错误通常与C标准版本…...

**基于Python的高通量测序数据质量控制与可视化全流程实战**在生物信息学领域,高通

基于Python的高通量测序数据质量控制与可视化全流程实战 在生物信息学领域&#xff0c;高通量测序&#xff08;HTS&#xff09;技术已成为基因组研究的核心工具。然而&#xff0c;原始测序数据往往存在质量问题&#xff0c;如低质量碱基、污染序列或接头残留等&#xff0c;直接…...