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

Python中的数据结构:五彩斑斓的糖果盒

在Python编程的世界里,数据结构就像是一个个五彩斑斓的糖果盒,每一种糖果都有其独特的味道和形状。这些多姿多彩,形状和味道各异的糖果盒子包括了:List(列表)、Tuple(元组)、Dictionary(字典)和Set(集合)。只有充分了解每种糖果的特性及何时品尝最佳,才是制作美味佳肴的关键。现在,就让我们一起打开这个充满奇幻的数据结构糖果盒,开始一场探索这些有趣糖果盒的奇妙之旅吧!

首先,让我们的脚步停留在糖果盒中的第一种特殊糖果——List。List这个小家伙就像是一个魔法糖果袋,它的大小可以随时变化,仿佛拥有了伸缩自如的超能力。你可以随意往里面添加、删除或者修改糖果,就像是一个充满惊喜的宝盒。比如,你有一个糖果清单,买了新的糖果就放进去,不再喜欢的糖果就拿出来,简直方便得不要不要的!在Python的世界里,我们这样创建一个List糖果盒:mylist = [1, 2, 3]。看,是不是简单又有趣?

接下来,我们来到了Tuple糖果盒前。Tuple和List有些相似,但它是一个守规矩的家伙。一旦创建了Tuple,就不能修改它的大小或内容,就像是一个密封的盒子。这种特性让Tuple成为了一个很好的数据存储选择,特别是当你需要确保数据不会被意外修改的时候。创建一个Tuple也很简单:mytuple = (1, 2, 3)。

现在,让我们走进Dictionary糖果盒的领地。Dictionary是一个喜欢配对的家伙,它由键(key)和值(value)组成。每个糖果都有一个独特的名字(键),而这个名字对应的就是糖果本身(值)。就像在电话簿中查找某个人的名字一样,我们可以快速找到Dictionary中的某个键对应的值。在Python中,我们这样创建一个Dictionary:mydict = {'Alice': 123, 'Bob': 456}。有了Dictionary,我们可以快速查找到某个键对应的值,非常方便。

最终,我们抵达了Set糖果的奇幻屋。Set糖果与众不同,每一颗都独一无二,宛如一个收藏家的梦寐以求的藏品陈列。当你希望从一大堆糖果中挑出那些独一无二的口味时,Set糖果就是你的完美助手。在Python的世界里,创建一盒Set糖果非常简单:myset = {1, 2, 3}。

在我们的故事中,List糖果盒、Tuple糖果盒、Dictionary糖果盒和Set糖果盒都是Python世界里的超级英雄,它们各自拥有独特的超能力,帮助我们解决各种编程难题。现在,你已经认识了这四种糖果盒,不妨去Python的世界里,和它们一起展开一场精彩的冒险吧!

最后给大家详细梳理一下Python中的数据结构(非常重要,建议收藏哦):


一、List(列表)

Python中的列表(List)是一种有序的集合,可以随时添加和删除其中的元素。以下是一些常用的列表操作:

1. 创建列表:使用方括号`[]`创建一个空列表,或者在方括号内添加元素来创建一个包含元素的列表。

empty_list = []
fruits = ['apple', 'banana', 'cherry']

2. 访问列表元素:通过索引访问列表中的元素,索引从0开始。

first_fruit = fruits[0]  # 'apple'
second_fruit = fruits[1]  # 'banana'

3. 修改列表元素:通过索引赋值来修改列表中的元素。

fruits[0] = 'orange'  # 将第一个元素改为'orange'

4. 添加元素:使用`append()`方法在列表末尾添加元素,或者使用`insert()`方法在指定位置插入元素。

fruits.append('grape')  # 在列表末尾添加'grape'
fruits.insert(1, 'kiwi')  # 在索引1处插入'kiwi'

5. 删除元素:使用`del`关键字删除指定索引的元素,或者使用`remove()`方法删除指定的元素。

del fruits[0]  # 删除第一个元素
fruits.remove('banana')  # 删除'banana'

6. 列表切片:使用切片操作符`:`获取列表的一部分。

sub_list = fruits[1:3]  # 获取索引1到2的元素,不包括索引3的元素

7. 列表长度:使用`len()`函数获取列表的长度。

length = len(fruits)  # 获取列表的长度

8. 列表排序:使用`sort()`方法对列表进行排序,或者使用`sorted()`函数返回一个新的排序后的列表。

fruits.sort()  # 对原列表进行排序
sorted_fruits = sorted(fruits)  # 返回一个新的排序后的列表

9. 列表遍历:使用`for`循环遍历列表中的元素。

for fruit in fruits:print(fruit)

10. 列表推导式:使用简洁的语法快速生成列表。

squares = [x**2 for x in range(1, 6)]  # 生成一个包含1到5的平方数的列表

二、Tuple(元组)

Python中的元组(Tuple)是一种不可变的序列类型,用于存储一组有序的数据。元组的元素可以是任意类型,包括数字、字符串、列表等。元组的创建很简单,只需将元素放在圆括号内即可。例如:

my_tuple = (1, 2, 3)

元组的主要特点如下:

1. 不可变性:元组一旦创建,其内容就不能被修改。这意味着我们不能添加、删除或更改元组中的元素。

2. 有序性:元组中的元素是有序的,可以通过索引访问。

3. 可重复性:元组可以包含重复的元素。

4. 支持嵌套:元组可以包含其他元组作为其元素。

5. 支持解包:可以将元组的元素分配给多个变量。

以下是一些常用的元组操作:

1. 访问元素:通过索引访问元组中的元素。

my_tuple = (1, 2, 3)
print(my_tuple[0])  # 输出:1

2. 切片:使用切片操作符获取元组的一部分。

my_tuple = (1, 2, 3, 4, 5)
print(my_tuple[1:4])  # 输出:(2, 3, 4)

3. 遍历元素:使用for循环遍历元组中的所有元素。

my_tuple = (1, 2, 3)
for item in my_tuple:print(item)

4. 解包:将元组的元素分配给多个变量。

my_tuple = (1, 2, 3)
a, b, c = my_tuple
print(a, b, c)  # 输出:1 2 3

5. 计算长度:使用len()函数获取元组的长度。

my_tuple = (1, 2, 3)
print(len(my_tuple))  # 输出:3

6. 连接元组:使用+运算符连接两个元组。

tuple1 = (1, 2, 3)
tuple2 = (4, 5, 6)
combined_tuple = tuple1 + tuple2
print(combined_tuple)  # 输出:(1, 2, 3, 4, 5, 6)

7. 检查元素是否存在:使用in关键字检查元素是否在元组中。

my_tuple = (1, 2, 3)
print(3 in my_tuple)  # 输出:True

三、Dictionary(字典)

Python中的字典(Dictionary)是一种可变的、无序的、键值对集合。字典中的键必须是唯一的,而值可以是任意类型的数据(数字、字符串、列表、另一个字典等)。

以下是一些常见的字典操作:

1. 创建字典:使用大括号 `{}` 或 `dict()` 函数创建一个空字典,或者使用键值对初始化字典。

# 使用大括号创建字典
my_dict = {'key1': 'value1', 'key2': 'value2'}
# 使用dict()函数创建字典
my_dict = dict(key1='value1', key2='value2')

2. 访问字典中的值:通过键来访问字典中的值。

value = my_dict['key1']

3. 修改字典:可以通过键来更新字典中的值。

my_dict['key1'] = 'new_value1'

4. 添加键值对:直接通过新的键来添加键值对。

my_dict['key3'] = 'value3'

5. 删除键值对:使用 `del` 关键字删除指定的键值对。

del my_dict['key1']

6. 检查键是否存在:使用 `in` 关键字检查字典中是否存在某个键。

if 'key1' in my_dict:print("Key exists")
else:print("Key does not exist")

7. 获取所有键和值:使用 `keys()` 和 `values()` 方法分别获取字典中的所有键和值。

keys = my_dict.keys()
values = my_dict.values()

8. 遍历字典:可以使用 `items()` 方法遍历字典中的键值对。

for key, value in my_dict.items():print(f"{key}: {value}")

总结:Python字典是一种非常有用的数据结构,可以用来存储和检索键值对。它提供了许多内置方法来操作字典,如添加、删除、查找和遍历元素。

四、Set(集合)

Python中的集合(Set)是一个无序的、不重复的元素序列。它的主要用途包括成员检测和消除重复元素。集合对象还支持数学运算,如并集、交集、差集和对称差分。

以下是一些常用的集合操作及其代码示例:

1. 创建集合:使用`set()`函数或大括号`{}`创建一个空集合,或者将一个列表或其他可迭代对象转换为集合。

empty_set = set()
numbers = [1, 2, 3, 4, 5]
number_set = set(numbers)

2. 添加元素:使用`add()`方法向集合中添加单个元素。

my_set = {1, 2, 3}
my_set.add(4)

3. 删除元素:使用`remove()`方法删除集合中的指定元素,如果元素不存在则抛出KeyError异常。使用`discard()`方法删除元素,如果元素不存在则不抛出异常。

my_set = {1, 2, 3}
my_set.remove(2)
my_set.discard(3)

4. 集合运算:可以使用集合的方法进行数学运算,如并集、交集、差集和对称差分。

A = {1, 2, 3}
B = {3, 4, 5}
# 并集
union_set = A.union(B)
# 交集
intersection_set = A.intersection(B)
# 差集
difference_set = A.difference(B)
# 对称差分
symmetric_difference_set = A.symmetric_difference(B)

5. 检查子集和超集:使用`issubset()`和`issuperset()`方法检查一个集合是否是另一个集合的子集或超集。

A = {1, 2, 3}
B = {1, 2}
C = {1, 2, 3, 4}
print(B.issubset(A))  # True
print(A.issuperset(B))  # True
print(A.issubset(C))  # False

6. 清空集合:使用`clear()`方法清空集合中的所有元素。

my_set = {1, 2, 3}
my_set.clear()

7. 不可变性:集合本身是不可变的,但可以包含可变类型的元素,如列表。然而,一旦创建了集合,就不能更改其内容。

my_set = {[1, 2], [3, 4]}  # 错误,因为列表是可变的

相关文章:

  • 北京网站建设多少钱?
  • 辽宁网页制作哪家好_网站建设
  • 高端品牌网站建设_汉中网站制作
  • 【深度学习入门篇 ⑦】PyTorch池化层
  • python自动化之用flask校验接口token(把token作为参数)
  • Web 安全之 VAPT (漏洞评估与渗透测试)详解
  • GB35114国密算法-GMSSL
  • list的模拟实现
  • 【排序算法】1.冒泡排序-C语言实现
  • C++基础语法:STL之容器(1)--容器概述和序列概述
  • 「Python」基于Gunicorn、Flask和Docker的高并发部署
  • 人像视频预处理【时间裁剪+画面裁切+调整帧率】
  • 工业三防平板可优化工厂流程管理
  • Redis--布隆过滤器
  • Windows与Linux双机热备软件推荐
  • 设计模式使用场景实现示例及优缺点(行为型模式——命令模式)
  • Mac安装stable diffusion 工具
  • 封装网络请求 鸿蒙APP HarmonyOS ArkTS
  • Android路由框架AnnoRouter:使用Java接口来定义路由跳转
  • es6要点
  • Git同步原始仓库到Fork仓库中
  • JavaScript服务器推送技术之 WebSocket
  • JS进阶 - JS 、JS-Web-API与DOM、BOM
  • laravel5.5 视图共享数据
  • spring boot下thymeleaf全局静态变量配置
  • SpringCloud集成分布式事务LCN (一)
  • win10下安装mysql5.7
  • XForms - 更强大的Form
  • 关于使用markdown的方法(引自CSDN教程)
  • 解决iview多表头动态更改列元素发生的错误
  • 开发基于以太坊智能合约的DApp
  • 前端相关框架总和
  • 微信小程序填坑清单
  • 正则表达式
  • 你对linux中grep命令知道多少?
  • ​​​​​​​STM32通过SPI硬件读写W25Q64
  • ​LeetCode解法汇总2182. 构造限制重复的字符串
  • ​Z时代时尚SUV新宠:起亚赛图斯值不值得年轻人买?
  • ​如何使用ArcGIS Pro制作渐变河流效果
  • # 安徽锐锋科技IDMS系统简介
  • #WEB前端(HTML属性)
  • #我与Java虚拟机的故事#连载13:有这本书就够了
  • (4)事件处理——(2)在页面加载的时候执行任务(Performing tasks on page load)...
  • (C语言)深入理解指针2之野指针与传值与传址与assert断言
  • (ISPRS,2021)具有遥感知识图谱的鲁棒深度对齐网络用于零样本和广义零样本遥感图像场景分类
  • (附源码)springboot宠物医疗服务网站 毕业设计688413
  • (十六)视图变换 正交投影 透视投影
  • (四)事件系统
  • (四十一)大数据实战——spark的yarn模式生产环境部署
  • (一)Mocha源码阅读: 项目结构及命令行启动
  • (原創) 如何刪除Windows Live Writer留在本機的文章? (Web) (Windows Live Writer)
  • (转)Mysql的优化设置
  • (转)大型网站架构演变和知识体系
  • .ai域名是什么后缀?
  • .babyk勒索病毒解析:恶意更新如何威胁您的数据安全
  • .net core 调用c dll_用C++生成一个简单的DLL文件VS2008
  • .Net Core中的内存缓存实现——Redis及MemoryCache(2个可选)方案的实现
  • .NET 将混合了多个不同平台(Windows Mac Linux)的文件 目录的路径格式化成同一个平台下的路径