Python数据结构:列表、元组、字典、集合

简介: Python 中的列表、元组、字典和集合是常用数据结构。列表(List)是有序可变集合,支持增删改查操作;元组(Tuple)与列表类似但不可变,适合存储固定数据;字典(Dictionary)以键值对形式存储,无序可变,便于快速查找和修改;集合(Set)为无序不重复集合,支持高效集合运算如并集、交集等。根据需求选择合适的数据结构,可提升代码效率与可读性。

在 Python 中,列表、元组、字典和集合是非常重要且常用的数据结构,它们各自有不同的特点和用途,以下为你详细介绍:

  1. 列表(List)
    定义:列表是一种有序、可变(可修改)的数据集合,使用方括号 [] 来表示,元素之间用逗号分隔。
    示例:
    python

fruits = ["apple", "banana", "cherry"]
常用操作:
访问元素:通过索引(从 0 开始)访问,如 fruits[0] 返回 "apple"。
修改元素:可以直接对指定索引的元素赋值,如 fruits[1] = "orange" 会将列表中第二个元素修改为 "orange"。
添加元素:使用 append() 方法在列表末尾添加元素,如 fruits.append("grape");使用 insert() 方法在指定位置插入元素,如 fruits.insert(1, "pear") 会在索引为 1 的位置插入 "pear"。
删除元素:使用 del 语句删除指定索引的元素,如 del fruits[0];使用 remove() 方法删除指定值的元素,如 fruits.remove("cherry")。
获取长度:使用 len() 函数,如 len(fruits) 返回列表中元素的个数。

  1. 元组(Tuple)
    定义:元组是一种有序、不可变(不可修改)的数据集合,使用圆括号 () 来表示,元素之间用逗号分隔。
    示例:
    python

point = (10, 20)
常用操作:
访问元素:和列表类似,通过索引访问,如 point[0] 返回 10。
获取长度:同样使用 len() 函数,如 len(point) 返回元组中元素的个数。
由于元组不可变,不能进行修改、添加和删除元素等操作。

  1. 字典(Dictionary)
    定义:字典是一种无序的、可变的数据集合,以键值对(key-value)的形式存储数据,使用花括号 {} 来表示,键和值之间用冒号 : 分隔,键值对之间用逗号分隔。
    示例:
    python

person = {
"name": "Alice",
"age": 30,
"city": "New York"
}
常用操作:
访问值:通过键来访问对应的值,如 person["name"] 返回 "Alice"。
修改值:直接对指定键赋值来修改对应的值,如 person["age"] = 31 会将年龄修改为 31。
添加键值对:直接新增键值对,如 person["job"] = "Engineer" 会在字典中添加一个新的键值对。
删除键值对:使用 del 语句删除指定键的键值对,如 del person["city"] 会删除 "city" 对应的键值对。
获取所有键:使用 keys() 方法,如 person.keys() 返回包含所有键的视图对象。
获取所有值:使用 values() 方法,如 person.values() 返回包含所有值的视图对象。
获取所有键值对:使用 items() 方法,如 person.items() 返回包含所有键值对的视图对象,每个元素是一个元组(键,值)。

  1. 集合(Set)
    定义:集合是一种无序、不重复的数据集合,使用花括号 {} 或 set() 函数来创建,元素之间用逗号分隔。
    示例:
    python

numbers = {1, 2, 3, 4, 4} # 重复的4会被自动去除
常用操作:
添加元素:使用 add() 方法,如 numbers.add(5) 会向集合中添加元素 5。
删除元素:使用 remove() 方法(如果元素不存在会报错)或 discard() 方法(元素不存在时不会报错),如 numbers.remove(3) 或 numbers.discard(3) 都会删除元素 3。
集合运算:支持并集(| 或 union() 方法)、交集(& 或 intersection() 方法)、差集(- 或 difference() 方法)等运算。例如:
python

set1 = {1, 2, 3}
set2 = {3, 4, 5}
union_set = set1 | set2 # 并集 {1, 2, 3, 4, 5}
intersection_set = set1 & set2 # 交集 {3}
difference_set = set1 - set2 # 差集 {1, 2}
AI写代码
这些数据结构在 Python 编程中广泛应用,根据不同的需求选择合适的数据结构可以提高代码的效率和可读性。

相关文章
|
5月前
|
存储 JavaScript Java
(Python基础)新时代语言!一起学习Python吧!(四):dict字典和set类型;切片类型、列表生成式;map和reduce迭代器;filter过滤函数、sorted排序函数;lambda函数
dict字典 Python内置了字典:dict的支持,dict全称dictionary,在其他语言中也称为map,使用键-值(key-value)存储,具有极快的查找速度。 我们可以通过声明JS对象一样的方式声明dict
346 1
|
6月前
|
存储 JSON 算法
Python集合:高效处理无序唯一数据的利器
Python集合是一种高效的数据结构,具备自动去重、快速成员检测和无序性等特点,适用于数据去重、集合运算和性能优化等场景。本文通过实例详解其用法与技巧。
193 0
|
7月前
|
存储 索引 Python
python 集合的所有基础知识
python 集合的所有基础知识
664 0
|
5月前
|
存储 Java 索引
(Python基础)新时代语言!一起学习Python吧!(二):字符编码由来;Python字符串、字符串格式化;list集合和tuple元组区别
字符编码 我们要清楚,计算机最开始的表达都是由二进制而来 我们要想通过二进制来表示我们熟知的字符看看以下的变化 例如: 1 的二进制编码为 0000 0001 我们通过A这个字符,让其在计算机内部存储(现如今,A 字符在地址通常表示为65) 现在拿A举例: 在计算机内部 A字符,它本身表示为 65这个数,在计算机底层会转为二进制码 也意味着A字符在底层表示为 1000001 通过这样的字符表示进行转换,逐步发展为拥有127个字符的编码存储到计算机中,这个编码表也被称为ASCII编码。 但随时代变迁,ASCII编码逐渐暴露短板,全球有上百种语言,光是ASCII编码并不能够满足需求
241 4
|
6月前
|
机器学习/深度学习 数据采集 并行计算
多步预测系列 | LSTM、CNN、Transformer、TCN、串行、并行模型集合研究(Python代码实现)
多步预测系列 | LSTM、CNN、Transformer、TCN、串行、并行模型集合研究(Python代码实现)
643 2
|
6月前
|
存储 JSON 数据管理
Python字典:高效数据管理的瑞士军刀
Python字典基于哈希表实现,提供接近O(1)的高效查找,支持增删改查、遍历、合并等丰富操作,广泛应用于计数、缓存、配置管理及JSON处理。其灵活性与性能使其成为数据处理的核心工具。
637 0
|
6月前
|
存储 缓存 安全
Python字典:从入门到精通的实用指南
Python字典如瑞士军刀般强大,以键值对实现高效数据存储与查找,广泛应用于配置管理、缓存、统计等场景。本文详解字典基础、进阶技巧、实战应用与常见陷阱,助你掌握这一核心数据结构,写出更高效、优雅的Python代码。
158 0
|
存储 算法
非递归实现后序遍历时,如何避免栈溢出?
后序遍历的递归实现和非递归实现各有优缺点,在实际应用中需要根据具体的问题需求、二叉树的特点以及性能和空间的限制等因素来选择合适的实现方式。
365 59
|
9月前
|
编译器 C语言 C++
栈区的非法访问导致的死循环(x64)
这段内容主要分析了一段C语言代码在VS2022中形成死循环的原因,涉及栈区内存布局和数组越界问题。代码中`arr[15]`越界访问,修改了变量`i`的值,导致`for`循环条件始终为真,形成死循环。原因是VS2022栈区从低地址到高地址分配内存,`arr`数组与`i`相邻,`arr[15]`恰好覆盖`i`的地址。而在VS2019中,栈区先分配高地址再分配低地址,因此相同代码表现不同。这说明编译器对栈区内存分配顺序的实现差异会导致程序行为不一致,需避免数组越界以确保代码健壮性。
194 0
栈区的非法访问导致的死循环(x64)
|
存储 C语言 C++
【C++数据结构——栈与队列】顺序栈的基本运算(头歌实践教学平台习题)【合集】
本关任务:编写一个程序实现顺序栈的基本运算。开始你的任务吧,祝你成功!​ 相关知识 初始化栈 销毁栈 判断栈是否为空 进栈 出栈 取栈顶元素 1.初始化栈 概念:初始化栈是为栈的使用做准备,包括分配内存空间(如果是动态分配)和设置栈的初始状态。栈有顺序栈和链式栈两种常见形式。对于顺序栈,通常需要定义一个数组来存储栈元素,并设置一个变量来记录栈顶位置;对于链式栈,需要定义节点结构,包含数据域和指针域,同时初始化栈顶指针。 示例(顺序栈): 以下是一个简单的顺序栈初始化示例,假设用C语言实现,栈中存储
710 77

热门文章

最新文章

推荐镜像

更多