Python基础教程(十一):数据结构汇总梳理

2024-06-12 09:28

本文主要是介绍Python基础教程(十一):数据结构汇总梳理,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

💝💝💝首先,欢迎各位来到我的博客,很高兴能够在这里和您见面!希望您在这里不仅可以有所收获,同时也能感受到一份轻松欢乐的氛围,祝你生活愉快!
💝💝💝如有需要请大家订阅我的专栏【Python系列】哟!我会定期更新相关系列的文章
💝💝💝关注!关注!!请关注!!!请大家关注下博主,您的支持是我不断创作的最大动力!!!

文章目录

    • 引言
      • 1. 列表(List)
      • 2. 元组(Tuple)
      • 3. 字典(Dictionary)
      • 4. 集合(Set)
    • 结论
    • 结束语

引言

在编程的世界里,数据结构是构建高效算法和软件系统的基础。Python,作为一种广泛使用的高级编程语言,提供了丰富的内置数据结构,使得处理数据变得既直观又强大。本文将深入探讨Python中的主要数据结构类型,包括列表(List)、元组(Tuple)、字典(Dictionary)和集合(Set),并通过具体案例来展示它们的应用场景。

1. 列表(List)

定义:列表是最常用的数据结构之一,它是一个有序的元素集合,可以存储任意类型的元素,并且允许重复。

特点

  • 可变性:列表是可变的,意味着可以在列表创建后添加、删除或修改其中的元素。
  • 索引:列表中的每个元素都有一个对应的索引,从0开始计数。

案例:假设我们需要维护一个学生名单,记录每位学生的姓名和成绩。

students = ["Alice", "Bob", "Charlie"]
scores = [90, 85, 88]# 添加新学生
students.append("David")
scores.append(92)# 修改某个学生的成绩
scores[1] = 87# 删除学生
del students[0]
del scores[0]# 打印当前学生名单和成绩
print(students)
print(scores)

2. 元组(Tuple)

定义:元组与列表相似,但它是不可变的,一旦创建就无法更改。

特点

  • 不可变性:元组创建后不能被修改,这使得它在需要确保数据不变的情况下非常有用。
  • 性能:由于不可变性,元组在某些情况下比列表更节省内存,运行速度也更快。

案例:假设我们有一个坐标点集合,每个点由其x和y坐标组成。

points = [(1, 2), (3, 4), (5, 6)]# 访问元组中的元素
print(points[0])       # 输出 (1, 2)
print(points[0][1])    # 输出 2# 遍历元组集合
for x, y in points:print(f"Point: ({x}, {y})")

3. 字典(Dictionary)

定义:字典是一种键值对的集合,其中每个键都是唯一的,用于快速查找值。

特点

  • 键唯一:字典中的键不能重复,如果尝试插入相同的键,后一个值将会覆盖前一个。
  • 快速查找:字典提供O(1)时间复杂度的查找性能。

案例:假设我们想要管理一个图书馆的图书信息,包括书名和作者。

library = {"The Great Gatsby": "F. Scott Fitzgerald","To Kill a Mockingbird": "Harper Lee"
}# 添加新书
library["1984"] = "George Orwell"# 查找作者
author = library["To Kill a Mockingbird"]
print(author)# 删除书籍
del library["The Great Gatsby"]# 遍历字典
for title, author in library.items():print(f"{title} by {author}")

4. 集合(Set)

定义:集合是一个无序的、不重复的元素集合。

特点

  • 唯一性:集合中的元素必须是唯一的,重复的元素在插入时会被自动去除。
  • 无序性:集合中的元素没有固定的顺序,因此不能通过索引访问。

案例:假设我们有一份待办事项清单,但不想有重复的任务。

tasks = {"Buy milk", "Walk the dog", "Pay bills", "Buy milk"}# 集合自动去重
print(tasks)  # 输出 {'Buy milk', 'Walk the dog', 'Pay bills'}# 添加任务
tasks.add("Read book")# 移除任务
tasks.remove("Walk the dog")# 检查任务是否存在
if "Pay bills" in tasks:print("Remember to pay your bills!")

结论

Python的内置数据结构提供了强大的功能,使开发者能够高效地管理和操作数据。理解并熟练运用这些数据结构对于编写高质量的Python代码至关重要。通过本文的介绍和案例分析,相信你已经掌握了Python数据结构的基本概念和使用方法。接下来,实践是检验学习成果的最佳方式,尝试在自己的项目中应用这些数据结构吧!


结束语

喜欢博主的同学,请给博主一丢丢打赏吧↓↓↓您的支持是我不断创作的最大动力哟!感谢您的支持哦😘😘😘
打赏下吧

💝💝💝如有需要请大家订阅我的专栏【Python系列】哟!我会定期更新相关系列的文章
💝💝💝关注!关注!!请关注!!!请大家关注下博主,您的支持是我不断创作的最大动力!!!

python相关文章索引文章链接
Python基础语法(一):标识符与保留字部分Python基础语法(一):标识符与保留字部分
Python基础语法(二):数据类型Python基础语法(二):数据类型
Python基础语法(三):运算符Python基础语法(三):运算符
Python基础语法(四):条件控制Python基础语法(四):条件控制
Python基础语法(五):循环语句Python基础语法(五):循环语句
Python基础语法(六):推导式编程Python基础语法(六):推导式编程
Python基础教程(七):函数编程-从基础到进阶Python基础教程(七):函数编程-从基础到进阶
Python基础教程(八):迭代器与生成器编程Python基础教程(八):迭代器与生成器编程
Python基础教程(九):Lambda 函数Python基础教程(九):Lambda 函数
Python基础教程(十):装饰器Python基础教程(十):装饰器

❤️❤️❤️觉得有用的话点个赞 👍🏻 呗。
❤️❤️❤️本人水平有限,如有纰漏,欢迎各位大佬评论批评指正!😄😄😄
💘💘💘如果觉得这篇文对你有帮助的话,也请给个点赞、收藏下吧,非常感谢!👍 👍 👍
🔥🔥🔥Stay Hungry Stay Foolish 道阻且长,行则将至,让我们一起加油吧!🌙🌙🌙

这篇关于Python基础教程(十一):数据结构汇总梳理的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1053822

相关文章

C++工程编译链接错误汇总VisualStudio

目录 一些小的知识点 make工具 可以使用windows下的事件查看器崩溃的地方 dumpbin工具查看dll是32位还是64位的 _MSC_VER .cc 和.cpp 【VC++目录中的包含目录】 vs 【C/C++常规中的附加包含目录】——头文件所在目录如何怎么添加,添加了以后搜索头文件就会到这些个路径下搜索了 include<> 和 include"" WinMain 和

Python 字符串占位

在Python中,可以使用字符串的格式化方法来实现字符串的占位。常见的方法有百分号操作符 % 以及 str.format() 方法 百分号操作符 % name = "张三"age = 20message = "我叫%s,今年%d岁。" % (name, age)print(message) # 我叫张三,今年20岁。 str.format() 方法 name = "张三"age

硬件基础知识——自学习梳理

计算机存储分为闪存和永久性存储。 硬盘(永久存储)主要分为机械磁盘和固态硬盘。 机械磁盘主要靠磁颗粒的正负极方向来存储0或1,且机械磁盘没有使用寿命。 固态硬盘就有使用寿命了,大概支持30w次的读写操作。 闪存使用的是电容进行存储,断电数据就没了。 器件之间传输bit数据在总线上是一个一个传输的,因为通过电压传输(电流不稳定),但是电压属于电势能,所以可以叠加互相干扰,这也就是硬盘,U盘

一道经典Python程序样例带你飞速掌握Python的字典和列表

Python中的列表(list)和字典(dict)是两种常用的数据结构,它们在数据组织和存储方面有很大的不同。 列表(List) 列表是Python中的一种有序集合,可以随时添加和删除其中的元素。列表中的元素可以是任何数据类型,包括数字、字符串、其他列表等。列表使用方括号[]表示,元素之间用逗号,分隔。 定义和使用 # 定义一个列表 fruits = ['apple', 'banana

Python应用开发——30天学习Streamlit Python包进行APP的构建(9)

st.area_chart 显示区域图。 这是围绕 st.altair_chart 的语法糖。主要区别在于该命令使用数据自身的列和指数来计算图表的 Altair 规格。因此,在许多 "只需绘制此图 "的情况下,该命令更易于使用,但可定制性较差。 如果 st.area_chart 无法正确猜测数据规格,请尝试使用 st.altair_chart 指定所需的图表。 Function signa

python实现最简单循环神经网络(RNNs)

Recurrent Neural Networks(RNNs) 的模型: 上图中红色部分是输入向量。文本、单词、数据都是输入,在网络里都以向量的形式进行表示。 绿色部分是隐藏向量。是加工处理过程。 蓝色部分是输出向量。 python代码表示如下: rnn = RNN()y = rnn.step(x) # x为输入向量,y为输出向量 RNNs神经网络由神经元组成, python

python 喷泉码

因为要完成毕业设计,毕业设计做的是数据分发与传输的东西。在网络中数据容易丢失,所以我用fountain code做所发送数据包的数据恢复。fountain code属于有限域编码的一部分,有很广泛的应用。 我们日常生活中使用的二维码,就用到foutain code做数据恢复。你遮住二维码的四分之一,用手机的相机也照样能识别。你遮住的四分之一就相当于丢失的数据包。 为了实现并理解foutain

python 点滴学

1 python 里面tuple是无法改变的 tuple = (1,),计算tuple里面只有一个元素,也要加上逗号 2  1 毕业论文改 2 leetcode第一题做出来

【数据结构】线性表:顺序表

文章目录 1. 线性表2. 顺序表2.1 概念及结构2.2 接口实现2.3 顺序表的问题及思考 1. 线性表 线性表是n个具有相同特性的数据元素的有限序列。 线性表是一种在实际中广泛使用的数据结构,常见的线性表:顺序表、链表、栈、队列、字符串… 线性表在逻辑上是线性结构,也就说是连续的一条直线。但是在物理结构上并不一定是连续的,线性表在物理上存储时,通常以数组和链式结构的形式

Python爬虫-贝壳新房

前言 本文是该专栏的第32篇,后面会持续分享python爬虫干货知识,记得关注。 本文以某房网为例,如下图所示,采集对应城市的新房房源数据。具体实现思路和详细逻辑,笔者将在正文结合完整代码进行详细介绍。接下来,跟着笔者直接往下看正文详细内容。(附带完整代码) 正文 地址:aHR0cHM6Ly93aC5mYW5nLmtlLmNvbS9sb3VwYW4v 目标:采集对应城市的