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

news2024/11/8 11:00:35

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 None

    def check(self):
        # 获取最后一个元素
        if not self.exist():
            lens = len(self.a)
            return self.a[lens - 1]
        else:
            return None

    def exist(self):
        #检查是否为空
        return len(self.a) == 0

    def 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 num
        else:
            return None

    def check(self):
        #查看队首元素
        if self.exist():
            return self.a[0]
        else:
            return None

    def exist(self):
        #检查空
        return len(self.a) == 0

    def 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.coloradmin.cn/o/2228485.html

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

相关文章

highcharts的datalabels标签格式化

Highcharts的数据标签格式化 代码如下 plotOptions: {series: {dataLabels: {enabled: true,format: {y:.2f} mm}} },y就是当前数据点的值,.2f代表2位小数,效果如下图

如何安装自动化测试工具katalon?

一、下载,最下面有免费的版本 Katalon Studio 免费下载 |卡塔隆 二、安装 第一次安装,需要输入注册信息,注册成功之后,就可以使用了。

从简单的demo开始让您逐步了解GetX的用法

目录 前言 一、从demo开始体现下Getx的用法 二、从最简单的功能开始 1.新建一个Flutter工程 2.GetX初体验 1.路由跳转 1.普通路由跳转 2.跳转并从堆栈中销毁当前页面 3.跳转并销毁之前所有页面 4.跳转以及传值 2.更方便的实现SnackBar、Dialog、BottomSheet 三、Ge…

【无标题】从网红长沙看背后的湘菜产业

“吃什么?” 相信这是每一个来长沙旅游的人,面临的第一个问题。 近年来,长沙以美食为媒介,成功吸引了无数游客的目光。而湘菜,作为湖南最具特色的美食名片,无疑在这场美食盛宴中占据了举足轻重的地位。 …

使用 Qt 实现自定义罗盘控件

用 Qt 编写一个简单的罗盘控件,该控件能够动态显示方向。该控件实现了一个带有北(N)和南(S)标记的圆形罗盘面盘,具有可以根据输入角度旋转的指针。 代码功能概述 该项目定义了一个 CompassWidget 类&…

算法|牛客网华为机试21-30C++

牛客网华为机试 上篇:算法|牛客网华为机试10-20C 文章目录 HJ21 简单密码HJ22 汽水瓶HJ23 删除字符串中出现次数最少的字符HJ24 合唱队HJ25 数据分类处理HJ26 字符串排序HJ27 查找兄弟单词HJ28 素数伴侣HJ29 字符串加解密HJ30 字符串合并处理 HJ21 简单密码 题目描…

使用 MMDetection 实现 Pascal VOC 数据集的目标检测项目练习(二) ubuntu的下载安装

首先,Linux系统是人工智能和深度学习首选系统。原因如下: 开放性和自由度:Linux 是一个开源操作系统,允许开发者自由修改和分发代码。这在开发和研究阶段非常有用,因为开发者可以轻松地访问和修改底层代码。社区支持:…

【ECMAScript标准】深入解析ES5:现代JavaScript的基石

🧑‍💼 一名茫茫大海中沉浮的小小程序员🍬 👉 你的一键四连 (关注 点赞收藏评论)是我更新的最大动力❤️! 📑 目录 🔽 前言1️⃣ ES5的概述2️⃣ ES5的关键特性3️⃣ ES5与之前版本的区别4️⃣ …

【万户软件-注册安全分析报告-无验证方式导致安全隐患】

前言 由于网站注册入口容易被黑客攻击,存在如下安全问题: 1. 暴力破解密码,造成用户信息泄露 2. 短信盗刷的安全问题,影响业务及导致用户投诉 3. 带来经济损失,尤其是后付费客户,风险巨大,造…

第2章 Android App开发基础

第 2 章 Android App开发基础 bilibili学习地址 github代码地址 本章介绍基于Android系统的App开发常识,包括以下几个方面:App开发与其他软件开发有什么不一 样,App工程是怎样的组织结构又是怎样配置的,App开发的前后端分离设计…

文本分段Chunking综述-RAG

为什么要分段? 即便大模型开始普通支持更大的上下文,但 RAG 技术目前仍然具有不可替代的价值,RAG 需要外部知识库。外部知识文档往往比较长,可能是包含几十页甚至数百页的内容,如果直接使用会存在以下问题&#xff1a…

R语言 | paletteer包:拥有2100多个调色板!

看到 PMID:39024031 文章的代码中&#xff0c;有颜色设置的语句&#xff1a; pal <- paletteer_d("ggsci::category20_d3")[c(1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18)]DimPlot(MM,reduction umap,group.by "sample",label F,pt.size 0.1,c…

怎么看AI大模型(LLM)、智能体(Agent)、知识库、向量数据库、知识图谱,RAG,AGI 的不同形态?

前言 在 AI 人工智能时代&#xff0c;智能体将会是未来最主流的大模型应用方式&#xff1f;人人都有机会通过智能体&#xff0c;解锁成为【超级个体】。 在人工智能的快速发展中&#xff0c;LLM、Agent、知识库、向量数据库、RAG&#xff08;检索增强生成&#xff09;、知识图…

照片不完整?来试试智能扩图,简直不要太满意!(不是广告)

生活中有些照片拍过之后&#xff0c;当时觉得很满意&#xff0c;但过段时间就恨当初没有拍一张完整的图片&#xff01; ——来自小白的感慨 当时跟家里的叮当一起去旅游&#xff0c;我给他拍了一张好看的照片&#xff1a; 今天这张照片如果是整图就好了&#xff01;好气哦&am…

idea连接数据库出现错误的解决方式

在使用idea连接数据库时&#xff0c;出现错误&#xff1a; The server has terminated the handshake. The protocol list option (enabledTLSProtocols) is set, this option might cause connection issues with some versions of MySQL. Consider removing the protocol li…

1. STM32环境搭建

1. MDK5(keil) 安装 安装包获取&#xff0c;可以在官网下载 https://www.keil.com/demo/eval/arm.htm 或者通过其他方式获取&#xff0c;下载 下载完有一个安装包和 “钥匙”&#xff0c;解压时关闭杀毒软件&#xff0c;防止被清理掉 1.1 安装 软件安装位置选择&#xff1a;…

map的oj题

第一题 . - 力扣&#xff08;LeetCode&#xff09; 第二题 单词识别_牛客题霸_牛客网 解题思路&#xff1a; 1&#xff0c;将数据放入set或者map中去重和更新次数, 即利用set和map的[ ] 2. 将数据放到vector 进行排序 &#xff0c;还应该利用仿函数写出 Compare() ,因为s…

Android13预置应用及授权开发

在android13中&#xff0c;要预置一个对讲应用&#xff0c;从预置和授权&#xff0c;梳理了一下&#xff0c;以便后续查询使用。在此记录 一放置应用 我的apk应用放在vendor下面&#xff0c; 路径&#xff1a;projectroot/vendor/fly/package/apps/DMR/flydmr.apk (vendor/fl…

【深度学习中的注意力机制9】11种主流注意力机制112个创新研究paper+代码——滑动窗口注意力(Sliding Window Attention)

【深度学习中的注意力机制9】11种主流注意力机制112个创新研究paper代码——滑动窗口注意力&#xff08;Sliding Window Attention&#xff09; 【深度学习中的注意力机制9】11种主流注意力机制112个创新研究paper代码——滑动窗口注意力&#xff08;Sliding Window Attention…