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

news2025/6/26 23:54:39

💝💝💝首先,欢迎各位来到我的博客,很高兴能够在这里和您见面!希望您在这里不仅可以有所收获,同时也能感受到一份轻松欢乐的氛围,祝你生活愉快!
💝💝💝如有需要请大家订阅我的专栏【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 道阻且长,行则将至,让我们一起加油吧!🌙🌙🌙

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

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

相关文章

信号与系统实验MATLAB-实验2-连续时间系统的时域分析

实验二 连续时间系统的时域分析 一、实验目的 1、掌握连续时间信号卷积及其MATLAB实现方法; 2、掌握连续系统的冲激响应、阶跃响应及其MATLAB实现方法; 3、掌握利用MATLAB求LTI系统响应的方法; 4、掌握利用MATLAB求函数卷积和解微分方程…

【递归、搜索与回溯】综合练习一

综合练习一 1.找出所有子集的异或总和再求和2.全排列 II3.电话号码的字母组合4.括号生成 点赞👍👍收藏🌟🌟关注💖💖 你的支持是对我最大的鼓励,我们一起努力吧!😃😃 1.找…

Django序列化器详解:普通序列化器与模型序列化器的选择与运用

系列文章目录 Django入门全攻略:从零搭建你的第一个Web项目Django ORM入门指南:从概念到实践,掌握模型创建、迁移与视图操作Django ORM实战:模型字段与元选项配置,以及链式过滤与QF查询详解Django ORM深度游&#xff…

Go Gin框架

一、Gin介绍 Gin是一个用Go编写的HTTPweb框架。它是一个类似于martini但拥有更好性能的API框架, 优于httprouter,速度提高了近 40 倍。点击此处访问Gin官方中文文档。 二、安装 1、安装Gin go get -u github.com/gin-gonic/gin 2、代码中引入 import "githu…

Aptos Builder Jam 亚洲首站|议程公布,无限畅想 Aptos 生态未来

作为一个新兴的 Layer1 公链,Aptos 自诞生之日起的理想便是 “A Layer 1 for everyone” 当 Web3 深陷熊市阴影之时,Aptos 奋力为开发者找到了全新的技术路径,正有 200 项目正在开发,并且已有大量 DeFi 项目落实部署工作&#xff…

席卷的B站《植物大战僵尸杂交版》V2.0.88整合包,PC和手机可用,含通关存档和视频教程!

今天给大家安利一款席卷B站,火爆全网的游戏——《植物大战僵尸杂交版》2.0.88整合包。 这个是网络上现存植物大战僵尸杂交版的最全整合,包含了修改工具,超强通关存档和高清工具。工具包有安装视频教程,支持手机版和pc多端使用&am…

工业烤箱设备厂家:专业制造,助力工业发展

随着现代工业的不断发展,工业烤箱设备在各个领域的应用越来越广泛。作为专业的工业烤箱设备厂家,我们致力于为客户提供高质量、高效率的烤箱设备,助力工业生产的顺利进行。 工业烤箱设备在工业生产中扮演着至关重要的角色。无论是电子、化工、…

数据结构重要知识总结

数组 数组(Array) 是一种很常见的数据结构。它由相同类型的元素(element)组成,并且是使用一块连续的内存来存储。 我们直接可以利用元素的索引(index)可以计算出该元素对应的存储地址。 数组…

DP:两个数组的dp问题

解决两个数组的dp问题的常用状态表示: 1、选取第一个字符串[0-i]区间以及第二个字符串[0,j]区间作为研究对象 2、根据题目的要求确定状态表示 字符串dp的常见技巧 1、空串是有研究意义的,引入空串可以帮助我们思考虚拟的边界如何进行初始化。 2、如…

Python数据分析与机器学习在医疗诊断中的应用

文章目录 📑引言一、数据收集与预处理1.1 数据收集1.2 数据预处理 二、特征选择与构建2.1 特征选择2.2 特征构建 三、模型选择与训练3.1 逻辑回归3.2 随机森林3.3 深度学习 四、模型评估与调优4.1 交叉验证4.2 超参数调优 五、模型部署与应用5.1 模型保存与加载5.2 …

深入解析Prometheus:强大的开源监控与告警系统

目录 引言 一、运维监控平台的设计思路 (一)设计思路 1.数据收集模块 2.数据提取模块 3.监控告警模块 (二)监控平台层级 二、Prometheus简介 (一)基本介绍 (二)核心特征 …

二叉树左右树交换

leetcode 226题 翻转二叉树 题目描述 给你一棵二叉树的根节点 root ,翻转这棵二叉树,并返回其根节点。 示例 1: 输入:root [4,2,7,1,3,6,9] 输出:[4,7,2,9,6,3,1]示例 2: 输入:root [2,1,3]…

聚道云软件连接器:企业数字化转型新动力

在当今数字化浪潮中,企业如何高效整合内部资源、优化业务流程、提升客户满意度,已成为每个企业亟需解决的问题。该公司作为行业内的佼佼者,近期借助聚道云软件连接器成功实现了飞鱼CRM与金蝶云星辰的对接,开启了数字化转型的新篇章…

探索uni-app x:下一代跨平台应用开发引擎

摘要 随着移动互联网的快速发展,跨平台应用开发的需求日益旺盛。传统的原生开发虽然性能卓越,但开发周期长、维护成本高。而Web应用开发虽然开发效率高,但性能往往不尽如人意。在这样的背景下,uni-app x应运而生,作为…

Go Module详解

文章目录 基本介绍相关环境变量Go Module的使用初始化项目(go mod init)管理依赖项(go mod edit)获取依赖项(go mod download)整理依赖项(go mod tidy)导入vendor目录(go…

单片机建立自己的库文件(3)

文章目录 前言一、新建工程二、将库文件复制到工程中1.在工程中添加.c文件2.主函数中添加LCD1602.h文件3.主函数中添加需要的LCD1602的显示文件 三、编译测试四、遇到问题五、最后完整.h .c总结 前言 提示:这里可以添加本文要记录的大概内容: 项目需要…

从“数据孤岛”、Data Fabric(数据编织)谈逻辑数据平台

提到逻辑数据平台,其核心在于“逻辑”,与之相对的便是“物理”。在过去,为了更好地利用和管理数据,我们通常会选择搭建数据仓库和数据湖,将所有数据物理集中起来。但随着数据量、用数需求和用数人员的持续激增&#xf…

细说ARM MCU的串口发送数据的实现过程

目录 1、条件及工程配置 2、实现串口发送的库函数 3、修改whlie(1)中的代码 4、修改回调函数 5、下载运行 前面的文章介绍了用串口的接收中断来接收数据,本文介绍通过串口从MCU向外发送数据。 1、条件及工程配置 文章依赖的硬件及工程配置同本文作者的其他文…

vscode插件开发之 - menu配置

上一遍博客介绍了如何从0到1搭建vscode插件开发的base code,这遍博客将重点介绍如何配置menu。通常,开发一款插件,会将插件显示在VSCode 左侧的活动栏(Activity Bar),那么如何配置让插件显示在Activity Bar…

利用Morph Studio平台免费生成AI视频教程和效果体验

今天体验一下生成AI视频平台,目前是免费的,但生成效果还是不错的,可以根据输入文字,或者上传图片,或者上传视频来自动生成视频。 访问官网,登录之后点击“create Library” ,比如我建了一个“AI视频”的Li…