python里的数据结构

news2024/11/24 4:32:11
  1. 列表(List)
    • 定义和特点
      • 列表是一种有序的可变序列,可包含不同类型的元素,如整数、字符串、列表等。可以通过索引访问和修改元素,索引从 0 开始。
    • 代码示例
my_list = [1, 2, 'apple', [4, 5]]
print(my_list[0])  # 输出列表中的第一个元素,即1
my_list[2] = 'banana'  # 修改列表中的第三个元素
print(my_list)
  1. 创建列表
    • 直接创建:使用方括号[]将元素括起来,元素之间用逗号分隔。例如:my_list = [1, 2, 3],可以包含不同类型的元素,如my_list_with_different_types = [1, "apple", True]
    • 使用list()函数创建:可以将其他可迭代对象(如元组、集合、字符串)转换为列表。例如,将元组转换为列表:my_tuple = (1, 2, 3)my_list_from_tuple = list(my_tuple),此时my_list_from_tuple的值为[1, 2, 3];将字符串转换为列表:my_string = "abc"my_list_from_string = list(my_string),得到['a', 'b', 'c']
  2. 访问元素
    • 通过索引访问:列表中的元素索引从 0 开始,使用方括号[]加上索引值来访问元素。例如:my_list = [1, 2, 3]print(my_list[0])会输出1print(my_list[2])会输出3。可以使用负数索引从列表末尾开始访问,如my_list[-1]表示最后一个元素,my_list[-2]表示倒数第二个元素。
  3. 修改元素
    • 通过索引修改:使用方括号[]和索引来修改指定位置的元素。例如:my_list = [1, 2, 3]my_list[1] = 4,此时my_list变为[1, 4, 3]
  4. 添加元素
    • append方法:用于在列表末尾添加一个元素。例如:my_list = [1, 2, 3]my_list.append(4),则my_list变为[1, 2, 3, 4]
    • insert方法:用于在指定位置插入一个元素。它接受两个参数,第一个参数是插入位置的索引,第二个参数是要插入的元素。例如:my_list = [1, 2, 3]my_list.insert(1, "apple"),此时my_list变为[1, "apple", 2, 3]
  5. 删除元素
    • remove方法:用于删除列表中指定的元素。如果元素不存在,会抛出ValueError异常。例如:my_list = [1, 2, 3]my_list.remove(2),此时my_list变为[1, 3]
    • pop方法:用于删除并返回指定索引位置的元素。如果不指定索引,默认删除并返回最后一个元素。例如:my_list = [1, 2, 3]popped_element = my_list.pop(1),此时my_list变为[1, 3]popped_element的值为2
    • del关键字:可以用于删除列表中的元素或整个列表。例如:my_list = [1, 2, 3]del my_list[0],此时my_list变为[2, 3];如果使用del my_list,则会删除整个列表。
  6. 列表切片
    • 基本语法:使用[start:stop:step]的形式来获取列表的一个子序列。start表示起始索引(包含),stop表示结束索引(不包含),step表示步长。例如:my_list = [1, 2, 3, 4, 5]print(my_list[1:4])会输出[2, 3, 4]print(my_list[::2])会输出[1, 3, 5]
  7. 列表排序
    • sort方法:用于对列表中的元素进行排序。默认是升序排序,可以通过sort(reverse = True)进行降序排序。例如:my_list = [3, 1, 2]my_list.sort(),此时my_list变为[1, 2, 3];如果使用my_list.sort(reverse = True),则my_list变为[3, 2, 1]
    • sorted函数:与sort方法类似,但sorted函数会返回一个新的已排序的列表,而原列表不变。例如:my_list = [3, 1, 2]new_sorted_list = sorted(my_list),此时my_list仍为[3, 1, 2],而new_sorted_list[1, 2, 3]
  8. 列表的拼接和重复
    • 拼接:可以使用+运算符将两个列表拼接在一起。例如:list1 = [1, 2]list2 = [3, 4]combined_list = list1 + list2,此时combined_list的值为[1, 2, 3, 4]
    • 重复:可以使用*运算符将列表重复指定的次数。例如:my_list = [1, 2]repeated_list = my_list * 3,此时repeated_list的值为[1, 2, 1, 2, 1, 2]
  9. 查找元素位置
    • index方法:用于查找元素在列表中的第一个位置索引。如果元素不存在,会抛出ValueError异常。例如:my_list = [1, 2, 3, 2]print(my_list.index(2))会输出1
  10. 统计元素个数
  • count方法:用于统计元素在列表中出现的次数。例如:my_list = [1, 2, 3, 2]print(my_list.count(2))会输出2
  1. 元组(Tuple)
    • 定义和特点
      • 元组是有序的不可变序列,一旦创建,元素不能修改。它也可以包含多种类型的元素,常用于存储相关联的数据。
    • 代码示例
my_tuple = (1, 2, 'apple')
print(my_tuple[1])  # 输出元组中的第二个元素,即2
# 以下代码会出错,因为元组是不可变的
# my_tuple[2] = 'banana'

  1. 集合(Set)
    • 定义和特点
      • 集合是无序的可变数据结构,元素具有唯一性,即不会包含重复的元素。主要用于去重、数学集合运算(如交集、并集、差集)等。
    • 代码示例
my_set = {1, 2, 3, 3}  # 自动去除重复元素,实际为{1, 2, 3}
my_set.add(4)  # 添加元素4
print(my_set)
another_set = {3, 4, 5}
intersection_set = my_set & another_set  # 求交集
print(intersection_set)
  1. 创建集合
    • 直接创建:使用花括号{}将元素括起来,元素之间用逗号分隔。例如:my_set = {1, 2, 3}。需要注意的是,如果要创建一个空集合,不能使用{},因为{}在 Python 中默认用于创建字典,空集合应该使用set()函数来创建,如empty_set = set()
    • 从可迭代对象创建:可以使用set()函数将其他可迭代对象(如列表、元组)转换为集合,从而去除重复元素。例如:my_list = [1, 2, 2, 3]my_set_from_list = set(my_list),此时my_set_from_list的值为{1, 2, 3}
  2. 添加元素
    • add方法:用于向集合中添加一个元素。如果添加的元素已经存在于集合中,集合不会发生变化。例如:my_set = {1, 2, 3}my_set.add(4),此时my_set变为{1, 2, 3, 4}
  3. 删除元素
    • remove方法:用于删除集合中指定的元素。如果元素不存在,会抛出KeyError异常。例如:my_set = {1, 2, 3}my_set.remove(2),此时my_set变为{1, 3}
    • discard方法:与remove类似,用于删除集合中的元素,但如果元素不存在,不会抛出异常。例如:my_set = {1, 2, 3}my_set.discard(4)my_set的值不变,仍为{1, 2, 3}
    • pop方法:随机删除并返回集合中的一个元素。由于集合是无序的,所以无法确定删除的是哪个元素。例如:my_set = {1, 2, 3}popped_element = my_set.pop()popped_element的值是集合中的一个元素(可能是123),同时my_set会少一个元素。
  4. 集合运算
    • 交集(&intersection方法):返回两个集合中共同的元素。例如:set1 = {1, 2, 3}set2 = {2, 3, 4}intersection_set = set1 & set2(或intersection_set = set1.intersection(set2)),intersection_set的值为{2, 3}
    • 并集(|union方法):返回包含两个集合中所有元素的集合。例如:set1 = {1, 2, 3}set2 = {2, 3, 4}union_set = set1 | set2(或union_set = set1.union(set2)),union_set的值为{1, 2, 3, 4}
    • 差集(-difference方法):返回一个集合中存在而另一个集合中不存在的元素。例如:set1 = {1, 2, 3}set2 = {2, 3, 4}difference_set = set1 - set2(或difference_set = set1.difference(set2)),difference_set的值为{1}
    • 对称差集(^symmetric_difference方法):返回两个集合中不重复的所有元素,即只存在于一个集合中的元素。例如:set1 = {1, 2, 3}set2 = {2, 3, 4}symmetric_difference_set = set1 ^ set2(或symmetric_difference_set = set1.symmetric_difference(set2)),symmetric_difference_set的值为{1, 4}
  5. 判断元素是否在集合中
    • 使用in关键字。例如:my_set = {1, 2, 3}print(1 in my_set)会输出Trueprint(4 in my_set)会输出False
  6. 集合的比较
    • issubset方法(<=:用于判断一个集合是否是另一个集合的子集。例如:set1 = {1, 2}set2 = {1, 2, 3}print(set1.issubset(set2))(或print(set1 <= set2))会输出True
    • issuperset方法(>=:用于判断一个集合是否是另一个集合的超集。例如:set1 = {1, 2, 3}set2 = {1, 2}print(set1.issuperset(set2))(或print(set1 >= set2))会输出True
    • isdisjoint方法:用于判断两个集合是否没有共同元素。例如:set1 = {1, 2}set2 = {3, 4}print(set1.isdisjoint(set2))会输出True
  1. 字典(Dictionary)
    • 定义和特点
      • 字典是无序的可变数据结构,由键 - 值(key - value)对组成。键必须是唯一的,值可以是任何类型。通过键来访问和修改值。
    • 代码示例
my_dict = {'name': 'John', 'age': 30, 'city': 'New York'}
print(my_dict['name'])  # 输出键为'name'的值,即'John'
my_dict['age'] = 31  # 修改键'age'的值
print(my_dict)

  1. 字符串(String)
    • 定义和特点
      • 字符串是有序的不可变序列,用于表示文本。可以通过索引访问字符,也可以进行切片操作。
    • 代码示例
my_string = "Hello, World!"
print(my_string[0])  # 输出字符串中的第一个字符,即'H'
print(my_string[7:])  # 切片操作,输出从索引7开始的字符,即'World!'
# 以下代码会出错,因为字符串是不可变的
# my_string[5] = '.'

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

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

相关文章

SpringSecurity创建一个简单的认证应用

1、SpringSecurity 的简介 Spring Security是一个功能强大且高度可定制的身份验证和访问控制框架&#xff0c;它是Spring项目组中用来提供安全认证服务的框架&#xff0c;能够为基于Spring的企业应用系统提供声明式的安全访问控制解决方案。 Spring Security 的前身是 Acegi …

力扣 LeetCode 236. 二叉树的最近公共祖先(Day10:二叉树)

解题思路&#xff1a; 后序遍历 注意&#xff1a; p和q其中一个就是它们的公共祖先的情况也考虑到了&#xff0c;假设q是公共祖先&#xff0c;遇到q就直接返回&#xff0c;相当于是下面一边为空&#xff0c;一边不为空的情况&#xff0c;返回不为空就一边即可 class Solutio…

AIGC(生成式AI)试用 18 -- AI Prompt

"忘了"&#xff0c;“记不清了”&#xff0c;“有点印像” “能给点提示吗&#xff1f;” ...... “哦&#xff0c;想起来了&#xff0c;是这样的。。。。。。” 这就是提示的作用&#xff1a;通过关键信息、结构化信息提示&#xff0c;引导完整的、…

Telegram bot Mini-App开发实践---Telegram简单介绍与初始化小程序获取window.Telegram.WebApp对象并解析

➡️【好看的灵魂千篇一律,有趣的鲲志一百六七!】- 欢迎认识我~~ 作者:鲲志说 (公众号、B站同名,视频号:鲲志说996) 科技博主:极星会 星辉大使 后端研发:java、go、python、TS,前电商、现web3 主理人:COC杭州开发者社区主理人 、周周黑客松杭州主理人、 AI爱好…

在Windows环境下打包Qt C++项目为独立可执行文件的完整指南

目录 1. 配置Qt环境变量步骤&#xff1a; 2. 使用Release模式编译项目步骤&#xff1a; 3. 使用windeployqt工具收集依赖项步骤&#xff1a; 4. 精简复制后的文件目录方法一&#xff1a;使用windeployqt的选项方法二&#xff1a;手动删除不必要的文件方法三&#xff1a;使用静态…

多摩川编码器协议及单片机使用

参考&#xff1a; https://blog.csdn.net/qq_28149763/article/details/132718177 https://mp.weixin.qq.com/s/H4XoR1LZSMH6AxsjZuOw6g 1、多摩川编码器协议 多摩川数据通讯是基于485 硬件接口标准NRZ 协议&#xff0c;通讯波特率为2.5Mbps 的串行通讯&#xff0c;采用差分两…

2024年11月22日Github流行趋势

项目名称&#xff1a;twenty 项目维护者&#xff1a;charlesBochet, lucasbordeau, Weiko, FelixMalfait, bosiraphael 项目介绍&#xff1a;正在构建一个由社区驱动的现代Salesforce替代方案。 项目star数&#xff1a;22,938 项目fork数&#xff1a;2,413 项目名称&#xff1…

使用Kubernetes部署第一个应用

目录 前提条件 启动集群 部署 nginx 应用 创建 YAML 文件 应用 YAML 文件 查看部署结果 理解Pods 相关命令 公布应用程序 问题背景 Kubernetes Service&#xff08;服务&#xff09;概述 服务和标签 为Deployment 创建一个 Service 伸缩应用程序 Scaling&#x…

第T8周:Tensorflow实现猫狗识别(1)

&#x1f368; 本文为&#x1f517;365天深度学习训练营 中的学习记录博客&#x1f356; 原作者&#xff1a;K同学啊 具体实现 &#xff08;一&#xff09;环境 语言环境&#xff1a;Python 3.10 编 译 器: PyCharm 框 架: &#xff08;二&#xff09;具体步骤 from absl.l…

使用 OpenAI 进行数据探索性分析(EDA)

探索性数据分析&#xff08;Exploratory Data Analysis, 简称 EDA&#xff09;是数据分析中不可或缺的环节&#xff0c;帮助分析师快速了解数据的分布、特征和潜在模式。传统的 EDA 通常需要手动编写代码或使用工具完成。现在&#xff0c;通过 OpenAI 的 GPT-4 模型&#xff0c…

力扣-Hot100-栈【算法学习day.40】

前言 ###我做这类文档一个重要的目的还是给正在学习的大家提供方向&#xff08;例如想要掌握基础用法&#xff0c;该刷哪些题&#xff1f;&#xff09;我的解析也不会做的非常详细&#xff0c;只会提供思路和一些关键点&#xff0c;力扣上的大佬们的题解质量是非常非常高滴&am…

低速接口项目之串口Uart开发(四)——UART串口实现FPGA内部AXILITE寄存器的读写控制

本节目录 一、设计背景 二、设计思路 三、逻辑设计框架 四、仿真验证 五、上板验证 六、往期文章链接本节内容 一、设计背景 通常&#xff0c;芯片手册或者IP都会提供一系列的用户寄存器以及相关的定义&#xff0c;用于软件开发人员进行控制底层硬件来调试&#xff0c;或封装…

记录第一次安装laravel项目

window系统 Laravel中文文档&#xff1a;https://laravel-docs.catchadmin.com/docs/11/getting-started/installation 1.使用composer安装全局laravel composer global require laravel/installer2.安装完成后在命令行输入laravel&#xff0c;如果报错&#xff1a;laravel不是…

PDF电子发票信息转excel信息汇总

PDF电子发票信息提取&#xff0c;支持将pdf发票文件夹下的剩所有发票&#xff0c;转为excel格式的信息&#xff0c;对于发票量比较大&#xff0c;不好统计&#xff0c;需要一个一个去统计的情况&#xff0c;可节省2个点以上的时间&#xff0c;一次下载&#xff0c;终身有效。 使…

性能优化(二):ANR

介绍 ANR全称Application Not Responding&#xff0c;意思就是程序未响应。如果一个应用无法响应用户的输入&#xff0c;系统就会弹出一个ANR对话框&#xff0c;用户可以自行选择继续等待亦或者是停止当前程序。 Android系统会监控程序的响应状况&#xff0c;一旦出现下面情况…

Idea修改Commit Changes模式、idea使用git缺少部分Commit Changes

文章目录 一、模式一1、页面效果如下2、如何打开为这种样式&#xff1f; 二、模式二1、页面效果如下2、如何打开为这种样式&#xff1f; 三、总结 前言&#xff1a;Idea中代码提交到git库时的commit Change有两种模式&#xff0c;每种模式的界面及功能都不太一样。 Commit Cha…

【UE5】在材质中计算模型在屏幕上的比例

ViewProperty节点有很多有意思的变量 例如用 ViewProperty 的 tan ⁡ ( FOV / 2 ) \tan(\text{FOV} / 2) tan(FOV/2) 输出&#xff0c;用它计算模型占屏幕的比例。 &#xff08;常用于for运算的次数优化&#xff0c;也可以用于各种美术效果&#xff09; ScaleOnScreen Obje…

【STM32】MPU6050简介

文章目录 MPU6050简介MPU6050关键块带有16位ADC和信号调理的三轴MEMS陀螺仪具有16位ADC和信号调理的三轴MEMS加速度计I2C串行通信接口 MPU6050对应的数据手册&#xff1a;MPU6050 陀螺仪加速度计 链接: https://pan.baidu.com/s/13nwEhGvsfxx0euR2hMHsyw?pwdv2i6 提取码: v2i6…

vue3 在哪些方便做了性能提升?

概要 Vue (读音 /vjuː/&#xff0c;类似于 view) 是一套用于构建用户界面的渐进式框架。vue2版本阶段已经证明了它的易用性和流行性&#xff0c;说明它已经足够优秀在构建前端应用领域&#xff0c;而vue3的推出更是将性能提升做了最大的优化&#xff0c;更加易用、灵活、高效&…

Vue3+element-plus 实现中英文切换(Vue-i18n组件的使用)

1、前言 在 Vue 3 项目中结合 vue-i18n 和 Element Plus 实现中英文切换是一个常见的需求。下面是一个详细的步骤指南&#xff0c;帮助你完成这个任务。 安装引入 1. 安装依赖 首先&#xff0c;你需要安装 vue-i18n 和 Element Plus。 npm install vue-i18nnext element-p…