python的数据结构列表方法及扩展(栈和队列)

python的数据结构

python的list方法

list.append()

添加一个元素到列表末尾。list,append(num)相当于a[len(a):] = [num]

a = [1,2,3,4,5]
a.append(6)
print(a)
a[len(a):] = [7]
print(a)

在这里插入图片描述

list.extend()

添加指定列表的所有元素。list.extend(nums)相当于a = a + nums

a = [1,2,3]
nums = [6,7,8,9]
a.extend(nums)
print(a)
a = a + nums
print(a)

!在这里插入图片描述

list.insert()

双参数:

在指定位置添加一个元素。

添加到最前面:a.insert(0,x)

添加到最后面:a.insert(len(a),x)(ps:相当于append)

指定位置添加:a.insert(index,x)

# 双参数
a = [1,2,3,4,5]
x = 6
a.insert(0,x)
print(a)
a.insert(len(a),x)
print(a)
index = 3
a.insert(index,x)
print(a)
```![在这里插入图片描述](https://i-blog.csdnimg.cn/direct/3df6274d1eab42b2a3334c8476c104ca.png#pic_center)![在这里插入图片描述](https://i-blog.csdnimg.cn/direct/49a0ba00f749411b8993e98fda8a88ad.png#pic_center)##### list.remove()> 从列表中删除一个数字,如果找不到这个数字返回错误(error)。```python
a = [1,2,3,4]
a.remove(3)
print(a)
a.remove(3) #没有该元素时会报错 

在这里插入图片描述

list.pop()

从列表中指定位置移除一个元素,元素可以可以为空,如果元素为空,默认移除最后一个。

指定移除list.pop(x)

元素为空时表示移除最后一个元素list.pop()

a = [1,2,3,4,5]
a.pop(0) # 移除第一个元素
print(a)
a.pop() # 移除最后一个元素
print(a)

在这里插入图片描述

list.clear()

清除列表中所有元素,等于del a[:]

使用示例:

a = [1,2,3,4]
a.clear()
print(a) # 打印空列表

在这里插入图片描述

list.count()

参数x返回该列表中出现了几次x

使用示例

a = [1,2,3,4,2,3]
print(a.count(2))
print(a.count(5))

在这里插入图片描述

list.排序

list.sort()将列表排列为升序列表。

list.reverse()将列表排列为降序列表。

使用示例:

a = [11,6,4,92,43,77]
a.sort()
print(a)
a.reverse()
print(a)

在这里插入图片描述

练习题目1:

要求:利用列表来写一个栈(先进后出)。

功能:1.压入栈顶。2.弹出栈顶。3.查看栈顶元素。4.检查空。5.获取栈大小。

class My_Stack:def __init__(self):# 初始化栈self.a = []def add(self, num):# 添加元素到栈底self.a.append(num)def pop(self):# 弹出元素if not self.exist():return self.a.pop()else:return Nonedef check(self):# 获取最后一个元素if not self.exist():lens = len(self.a)return self.a[lens - 1]else:return Nonedef exist(self):#检查是否为空return len(self.a) == 0def size(self):#获取栈大小return len(self.a)

练习题目2:

要求:利用列表来写一个队列(先进先出)。

功能:1.压入队列。2.弹出队列。3.查看队首元素。4.检查空。5.获取队列大小。

class myQueue:def __init__(self):self.a = []def add(self, num):# 添加元素self.a.append(num)def pop(self):#弹出队列if not self.exist():num = self.a[0]self.a.remove(num)return numelse:return Nonedef check(self):#查看队首元素if self.exist():return self.a[0]else:return Nonedef exist(self):#检查空return len(self.a) == 0def size(self):#获取队列大小return len(self.a)

collections.deque()队列

# 导入
from collections import deque
# 1.创建队列
queue = deque()
# 2.添加元素
queue.append('a')
# 3.队首移除元素
queue.popleft()
# 4.查看队首元素
queue.[0]
# 5.检查队列是否为空
isEmpty = len(queue) == 0
# 6.获取队列大小
len(queue)

列表推导式

从序列中创建新的列表的简单途径,将操作应用于每一个元素,获得新的列表。

示例1:

ver = [2,4,6]
# 1.第一种变法
ver = [3*x for x in ver]
print(ver)
# 2.第二种变法
ver = [2,4,6]
ver = [[x,x**2] for x in ver]
print(ver)

在这里插入图片描述

if 作为过滤器

# 语法格式
ver = [1,2,3,4]
ver = [3 * x for x in  ver if x>3]
print(ver)

在这里插入图片描述

示例:

# 使用两个元素
vec = [2,4,6]
vec2 = [4,3,-9]
vec3 = [x,y for x in vec for y in vec2 if x > 2]
print(vec3)

在这里插入图片描述

复杂嵌套

# round() 取小数点后i位
vec = [str(round(355 / 113, i)) for i in range(1, 6)]
print(vec)

在这里插入图片描述

del语句

可以根据索引从列表中删除一个或多个元素。

使用示例:

a = [1,2,3,4,5]
# 使用索引删除
del(a[0])
print(a)
# 删除索引范围内所有的元素
del(a[1:2])
print(a)
# 删除列表中所有元素
del(a[:])

不仅如此,元组、序列、字典、集合都属于python的数据结构

数据的遍历

item:遍历为下一个数值仅仅用于字典【dict】

enumerate():得到遍历列表的下标以及数值

zip():遍历多个列表

reversed():不改变原有序列进行倒叙遍历

sort():不改变原有序列进行顺序遍历

具体使用示例:

a = [9, 36, 4, 33, 45, 67, 29, 64, 32, 19, 75]# enumerate
for v, k in enumerate(a):print('i:' + str(v) + ' num:' + str(k), end=', ')
# zip
print()
b = [2, 3, 54, 62, 17, 89]
for v, k in zip(a, b):print(v, k, end=', ')
# reversed sort
print()
for i in reversed(range(len(a))):print(i, end=',')
# sort
print()
for i in sorted(range(len(a))):print(i, end=',')

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.xdnf.cn/news/390.html

如若内容造成侵权/违法违规/事实不符,请联系一条长河网进行投诉反馈,一经查实,立即删除!

相关文章

我与Linux的爱恋:基础IO 文件描述符重定向缓冲区

​ ​ 🔥个人主页:guoguoqiang. 🔥专栏:Linux的学习 文章目录 文件描述符文件描述符分配规则访问文件的本质 重定向原理缓冲区的理解 文件描述符 通过上述内容,我们知道使用 open 系统调用打开文件时,系…

Java每日刷题之二分算法

34. 在排序数组中查找元素的第一个和最后一个位置 - 力扣(LeetCode) 转化 通过题目时间复杂度为O(logN),我们就可以联想到二分算法,但是我们前面学到的算法,是查找出,有序数组里的值,并不是求其中的范围&a…

qt QBrush详解

1、概述 QBrush是Qt框架中的一个基本图形对象类,它主要用于定义图形的填充模式。QBrush可以用于填充如矩形、椭圆形、多边形等形状,也可以用于绘制背景等。通过QBrush,可以设置填充的颜色、样式(如实心、渐变、纹理等&#xff09…

postman如何安装旧版本不升级(以9.31和11.10版本为例)

postman版本超过10.x(包含10.x),有个大的麻烦,就是需要登录账号,如果网络不佳(其实是外网受限),那就很难受了 功能页面都进不去了!而8.x /9.x等以下版本就不需要登录了。 比如9.31.30这个版本就…

线程函数和线程启动的几种不同形式

线程函数和线程启动的几种不同形式 在C中&#xff0c;线程函数和线程启动可以通过多种形式实现。以下是几种常见的形式&#xff0c;并附有相应的示例代码。 1. 使用函数指针启动线程 最基本的方式是使用函数指针来启动线程。 示例代码&#xff1a; #include <iostream&g…

Arm和高通闹翻在即,或影响骁龙 8 Elite

原文转载修改自&#xff08;更多互联网新闻/搞机小知识&#xff09;&#xff1a; Arm向高通下达最后通牒&#xff0c;骁龙 8 Elite或受影响 其实对于小江这个不咋关注安卓圈的用户来说&#xff0c;高通和Arm大概就是秤不离砣&#xff0c;砣不离秤的关系。不过在看了今天的最新…

【学术精选】SCI期刊《Electronics》特刊“New Challenges in Remote Sensing Image Processing“

英文名称&#xff1a;New Challenges in Remote Sensing Image Processing 中文名称&#xff1a;"遥感图像处理的新挑战"特刊 期刊介绍 “New Challenges in Remote Sensing Image Processing”特刊隶属于《Electronics》期刊&#xff0c;聚焦遥感图像处理领域快速…

人机环境系统智能是东方天地人思想与西方科技思维的融合

西方科技思维常常受到还原主义的影响&#xff0c;这种思维方式通常强调将复杂系统拆解为更简单的部分进行分析&#xff08;比如物理的分子、原子、电子、夸克……&#xff0c;数理中的分解因式&#xff09;。以下是还原主义的一些特点&#xff1a; 分析方法&#xff1a;强调通过…

深度学习:梯度下降算法简介

梯度下降算法简介 梯度下降算法 我们思考这样一个问题&#xff0c;现在需要用一条直线来回归拟合这三个点&#xff0c;直线的方程是 y w ^ x b y \hat{w}x b yw^xb&#xff0c;我们假设斜率 w ^ \hat{w} w^是已知的&#xff0c;现在想要找到一个最好的截距 b b b。 一条…

瑞芯微RK3566/RK3568 Android11下该如何默认屏蔽导航栏/状态栏?看这篇文章就懂了

本文介绍瑞芯微RK3566/RK3568在Android11系统下&#xff0c;默认屏蔽导航栏/状态栏方法&#xff0c;使用触觉智能Purple Pi OH鸿蒙开发板演示&#xff0c;搭载了瑞芯微RK3566芯片&#xff0c;类树莓派设计&#xff0c;Laval官方社区主荐&#xff0c;已适配全新OpenHarmony5.0 R…

Python | Leetcode Python题解之第519题随机翻转矩阵

题目&#xff1a; 题解&#xff1a; class Solution:def __init__(self, m: int, n: int):self.m mself.n nself.total m * nself.map {}def flip(self) -> List[int]:x random.randint(0, self.total - 1)self.total - 1# 查找位置 x 对应的映射idx self.map.get(x,…

从0学习React(6)

这两天在写IT资产管理的时候&#xff0c;对于前端&#xff0c;我一直没有任何头绪&#xff0c;不知道怎么写。因为我之前并没有学习过前端方面的知识&#xff0c;我学的都是后端。我在写后端接口的时候&#xff0c;我是自己有一些基础的&#xff0c;然后我又参照着模仿着一些很…

单个相机矫正畸变

1、通过标定助手获取到内参外参&#xff0c;外参在此无效&#xff0c;只用到了内参 2、然后通过halcon算子进行矫正 参考&#xff1a;超人视觉

乘云而上,OceanBase再越山峰

一座山峰都是一个挑战&#xff0c;每一次攀登都是一次超越。 商业数据库时代&#xff0c;面对国外数据库巨头这座大山&#xff0c;实现市场突破一直都是中国数据库产业多年夙愿&#xff0c;而OceanBase在金融核心系统等领域的攻坚克难&#xff0c;为产业突破交出一副令人信服的…

laravel: Breeze 和 Blade, 登录 注册等

composer require laravel/breeze --dev php artisan breeze:install php artisan migrate npm install npm run build php artisan route:clear http://laravel-dev.cn/ http://laravel-dev.cn/register http://laravel-dev.cn/login

VS+Qt解决提升控件后,包含头文件格式不对问题处理

一、前言 VSQt 提升控件后&#xff0c;在uic目录下会生成ui相关的初始化文件&#xff0c;对于提升的控件头文件包含的格式为#include<> 而非 #include “ ” 导致无法找到头文件。如果手动修改为 #include “ ”相当麻烦&#xff0c;甚至每次编译都要修改一遍&#xff0c…

一些硬件知识【2024/11/3】

MLCC电容的ESR比较小&#xff0c;但是他的缺点是容量通常比较低&#xff1b;电解电容的容量比较大&#xff0c;但是他的ESR比较大&#xff1b;而钽电容介于两者之间&#xff0c;是MLCC找不到合适的容值比较大的时候&#xff0c;找钽电容&#xff1a; LC谐振电路&#xff1a; 五…

简单的ELK部署学习

简单的ELK部署学习 1. 需求 我们公司现在使用的是ELK日志跟踪&#xff0c;在出现问题的时候&#xff0c;我们可以快速定为到问题&#xff0c;并且可以对日志进行分类检索&#xff0c;比如对服务名称&#xff0c;ip , 级别等信息进行分类检索。此文章为本人学习了解我们公司的…

SpringBoot篇(自动装配原理)

目录 一、自动装配机制 1. 简介 2. 自动装配主要依靠三个核心的关键技术 3. run()方法加载启动类 4. 注解SpringBootApplication包含了多个注解 4.1 SpringBootConfiguration 4.2 ComponentScan 4.3 EnableAutoConfiguration 5. SpringBootApplication一共做了三件事 …

科学减肥:基础代谢减肥法

基础代谢减肥法是什么&#xff1f; 相信有很多人在减肥的路上都有做过努力&#xff0c;但是效果往往和努力不匹配。那是因为很多时候在细节上面没有做对&#xff0c;大家都是根据自己的理解去努力&#xff0c;而没有深度去了解过身体营养成分构成与吸收。 没科学了解过减肥的原…