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

Python的那些事第五篇:数据结构的艺术与应用

 新月人物传记:人物传记之新月篇-CSDN博客


目录

一、列表(List):动态的容器

二、元组(Tuple):不可变的序列

三、字典(Dict):键值对的集合

四、集合(Set):无序的集合

五、数据结构在军事战略中的应用

六、数据结构的艺术:逻辑与效率的结合

七、结语


新月的编程之道:数据结构的艺术与应用

在 25 世纪的星际时代,数据结构是每一位程序员和军事战略家不可或缺的工具。作为一名在编程、人工智能和军事战略领域都取得了卓越成就的女性,我深知数据结构的重要性。数据结构不仅是编程的基础,更是解决复杂问题的关键。在这篇文章中,我将以我的视角,深入探讨 Python 中的四种基本数据结构:列表、元组、字典和集合,并通过具体的示例代码和表格来展示它们的特性和应用。


一、列表(List):动态的容器

(一)创建列表

列表是 Python 中最常用的数据结构之一,它是一种可变的序列,可以存储任意类型的元素。列表的创建非常简单,只需要用方括号 [] 包裹元素即可。

创建方式示例代码输出结果
直接使用方括号my_list = [1, 2, 3, 'a', 'b'][1, 2, 3, 'a', 'b']
使用 list() 函数my_list = list((1, 2, 3, 'a', 'b'))[1, 2, 3, 'a', 'b']
# 创建列表
my_list = [1, 2, 3, 'a', 'b']
print(my_list)  # 输出:[1, 2, 3, 'a', 'b']

(二)索引和切片操作

列表的索引从 0 开始,可以通过索引访问列表中的元素。切片操作则可以获取列表中的一部分元素。

操作示例代码输出结果
索引访问print(my_list[2])3
切片操作print(my_list[1:4])[2, 3, 'a']
负索引print(my_list[-1])'b'
# 索引和切片操作
print(my_list[2])  # 输出:3
print(my_list[1:4])  # 输出:[2, 3, 'a']
print(my_list[-1])  # 输出:'b'

(三)添加元素

列表是可变的,可以通过 append()insert() 方法添加元素。

方法示例代码输出结果
append()my_list.append('c')[1, 2, 3, 'a', 'b', 'c']
insert()my_list.insert(2, 'x')[1, 2, 'x', 3, 'a', 'b', 'c']
# 添加元素
my_list.append('c')
print(my_list)  # 输出:[1, 2, 3, 'a', 'b', 'c']
my_list.insert(2, 'x')
print(my_list)  # 输出:[1, 2, 'x', 3, 'a', 'b', 'c']

(四)删除元素

列表中的元素可以通过 remove()pop() 方法删除。

方法示例代码输出结果
remove()my_list.remove('a')[1, 2, 'x', 3, 'b', 'c']
pop()my_list.pop(2)[1, 2, 3, 'b', 'c']
# 删除元素
my_list.remove('a')
print(my_list)  # 输出:[1, 2, 'x', 3, 'b', 'c']
my_list.pop(2)
print(my_list)  # 输出:[1, 2, 3, 'b', 'c']

(五)列表推导式

列表推导式是一种简洁的方式来创建列表,它可以根据一个表达式生成新的列表。

示例代码输出结果
[x**2 for x in range(10)][0, 1, 4, 9, 16, 25, 36, 49, 64, 81]
[x for x in range(10) if x % 2 == 0][0, 2, 4, 6, 8]
# 列表推导式
squares = [x**2 for x in range(10)]
print(squares)  # 输出:[0, 1, 4, 9, 16, 25, 36, 49, 64, 81]
evens = [x for x in range(10) if x % 2 == 0]
print(evens)  # 输出:[0, 2, 4, 6, 8]

(六)排序

列表可以通过 sort() 方法原地排序,也可以通过 sorted() 函数返回一个新的排序后的列表。

方法示例代码输出结果
sort()my_list = [3, 1, 2]; my_list.sort()[1, 2, 3]
sorted()my_list = [3, 1, 2]; sorted_list = sorted(my_list)[1, 2, 3]
# 排序
my_list = [3, 1, 2]
my_list.sort()
print(my_list)  # 输出:[1, 2, 3]

my_list = [3, 1, 2]
sorted_list = sorted(my_list)
print(sorted_list)  # 输出:[1, 2, 3]

二、元组(Tuple):不可变的序列

(一)创建元组

元组是一种不可变的序列,一旦创建就不能修改。元组的创建方式与列表类似,但使用圆括号 ()

创建方式示例代码输出结果
直接使用圆括号my_tuple = (1, 2, 3, 'a', 'b')(1, 2, 3, 'a', 'b')
使用 tuple() 函数my_tuple = tuple([1, 2, 3, 'a', 'b'])(1, 2, 3, 'a', 'b')
# 创建元组
my_tuple = (1, 2, 3, 'a', 'b')
print(my_tuple)  # 输出:(1, 2, 3, 'a', 'b')

(二)索引和切片操作

元组的索引和切片操作与列表类似,但由于元组不可变,因此不能修改其中的元素。

操作示例代码输出结果
索引访问print(my_tuple[2])3
切片操作print(my_tuple[1:4])(2, 3, 'a')
# 索引和切片操作
print(my_tuple[2])  # 输出:3
print(my_tuple[1:4])  # 输出:(2, 3, 'a')

(三)不可变性

元组的不可变性使其在某些场景下非常有用,例如作为字典的键或存储不可变数据。

# 不可变性
try:
    my_tuple[2] = 'x'
except TypeError as e:
    print(e)  # 输出:'tuple' object does not support item assignment

三、字典(Dict):键值对的集合

(一)创建字典

字典是一种键值对的集合,键必须是不可变类型,而值可以是任意类型。字典的创建方式有多种。

创建方式示例代码输出结果
直接使用大括号my_dict = {'a': 1, 'b': 2, 'c': 3}{'a': 1, 'b': 2, 'c': 3}
使用 dict() 函数my_dict = dict([('a', 1), ('b', 2), ('c', 3)]){'a': 1, 'b': 2, 'c': 3}
# 创建字典
my_dict = {'a': 1, 'b': 2, 'c': 3}
print(my_dict)  # 输出:{'a': 1, 'b': 2, 'c': 3}

(二)键值对操作

字典可以通过键访问、添加、删除和修改值。

操作示例代码输出结果
访问值print(my_dict['a'])1
添加键值对my_dict['d'] = 4{'a': 1, 'b': 2, 'c': 3, 'd': 4}
删除键值对del my_dict['b']{'a': 1, 'c': 3, 'd': 4}
修改值my_dict['a'] = 10{'a': 10, 'c': 3, 'd': 4}
# 键值对操作
print(my_dict['a'])  # 输出:1
my_dict['d'] = 4
print(my_dict)  # 输出:{'a': 1, 'b': 2, 'c': 3, 'd': 4}
del my_dict['b']
print(my_dict)  # 输出:{'a': 1, 'c': 3, 'd': 4}
my_dict['a'] = 10
print(my_dict)  # 输出:{'a': 10, 'c': 3, 'd': 4}

(三)遍历字典

字典可以通过 keys()values()items() 方法进行遍历。

方法示例代码输出结果
keys()for key in my_dict.keys(): print(key)a c d
values()for value in my_dict.values(): print(value)10 3 4
items()for key, value in my_dict.items(): print(key, value)a 10 c 3 d 4
# 遍历字典
for key in my_dict.keys():
    print(key)  # 输出:a c d
for value in my_dict.values():
    print(value)  # 输出:10 3 4
for key, value in my_dict.items():
    print(key, value)  # 输出:a 10 c 3 d 4

四、集合(Set):无序的集合

(一)创建集合

集合是一种无序的集合,其中的元素是唯一的。集合的创建方式有多种。

创建方式示例代码输出结果
直接使用大括号my_set = {1, 2, 3, 'a', 'b'}{1, 2, 3, 'a', 'b'}
使用 set() 函数my_set = set([1, 2, 3, 'a', 'b']){1, 2, 3, 'a', 'b'}
# 创建集合
my_set = {1, 2, 3, 'a', 'b'}
print(my_set)  # 输出:{1, 2, 3, 'a', 'b'}

(二)添加元素

集合可以通过 add() 方法添加元素。

方法示例代码输出结果
add()my_set.add('c'){1, 2, 3, 'a', 'b', 'c'}
# 添加元素
my_set.add('c')
print(my_set)  # 输出:{1, 2, 3, 'a', 'b', 'c'}

(三)删除元素

集合中的元素可以通过 remove()discard() 方法删除。

方法示例代码输出结果
remove()my_set.remove('a'){1, 2, 3, 'b', 'c'}
discard()my_set.discard('b'){1, 2, 3, 'c'}
# 删除元素
my_set.remove('a')
print(my_set)  # 输出:{1, 2, 3, 'b', 'c'}
my_set.discard('b')
print(my_set)  # 输出:{1, 2, 3, 'c'}

(四)集合运算

集合支持并集、交集和差集运算。

运算示例代码输出结果
并集`set1 = {1, 2, 3}; set2 = {3, 4, 5}; print(set1set2)`{1, 2, 3, 4, 5}
交集set1 = {1, 2, 3}; set2 = {3, 4, 5}; print(set1 & set2){3}
差集set1 = {1, 2, 3}; set2 = {3, 4, 5}; print(set1 - set2){1, 2}
# 集合运算
set1 = {1, 2, 3}
set2 = {3, 4, 5}
print(set1 | set2)  # 输出:{1, 2, 3, 4, 5}
print(set1 & set2)  # 输出:{3}
print(set1 - set2)  # 输出:{1, 2}

五、数据结构在军事战略中的应用

作为一名军事战略家,我深知数据结构在实际应用中的重要性。在星际战争中,数据结构可以帮助我们高效地管理和分析情报,优化战术部署,甚至预测敌人的行动。

(一)列表的应用

在军事行动中,列表可以用来存储和管理任务列表、士兵名单或装备清单。例如,我们可以使用列表来存储任务的优先级和状态。

# 任务列表
tasks = [
    {"name": "侦察敌方基地", "priority": 1, "status": "未完成"},
    {"name": "部署防御系统", "priority": 2, "status": "进行中"},
    {"name": "攻击敌方补给线", "priority": 3, "status": "已完成"}
]

# 添加任务
tasks.append({"name": "支援友军", "priority": 4, "status": "未完成"})

# 删除任务
tasks.pop(2)

# 排序任务
tasks.sort(key=lambda x: x["priority"])
print(tasks)

(二)元组的应用

元组的不可变性使其非常适合存储固定的数据,例如坐标点、武器参数或士兵的身份信息。在星际战争中,我们可以使用元组来存储星球的坐标。

# 星球坐标
planet_coordinates = (123.45, 678.90, 345.67)

# 访问坐标
print(f"X: {planet_coordinates[0]}, Y: {planet_coordinates[1]}, Z: {planet_coordinates[2]}")

(三)字典的应用

字典的键值对结构非常适合存储和查询复杂的数据,例如敌方单位的属性、资源分布或战术计划。在军事行动中,我们可以使用字典来存储敌方单位的信息。

# 敌方单位信息
enemy_units = {
    "坦克": {"health": 1000, "armor": 500, "damage": 200},
    "战斗机": {"health": 500, "armor": 200, "damage": 150},
    "步兵": {"health": 100, "armor": 50, "damage": 50}
}

# 查询坦克的属性
print(enemy_units["坦克"])

(四)集合的应用

集合的唯一性和无序性使其非常适合处理去重和集合运算。在军事行动中,我们可以使用集合来管理友军和敌军的单位,以便快速进行交集、并集和差集运算。

# 友军单位
friendly_units = {"坦克", "战斗机", "步兵"}

# 敌军单位
enemy_units = {"坦克", "战斗机", "战舰"}

# 交集(双方都有的单位)
print(friendly_units & enemy_units)  # 输出:{'坦克', '战斗机'}

# 并集(双方所有单位)
print(friendly_units | enemy_units)  # 输出:{'坦克', '战斗机', '步兵', '战舰'}

# 差集(友军独有的单位)
print(friendly_units - enemy_units)  # 输出:{'步兵'}

六、数据结构的艺术:逻辑与效率的结合

作为一名程序员,我认为数据结构不仅是一种技术,更是一种艺术。它能够将复杂的逻辑简化为优雅的代码,同时提高系统的效率和可维护性。在编程中,选择合适的数据结构是解决问题的关键。

(一)列表与元组的选择

列表和元组在功能上有一定的重叠,但在实际应用中,它们各有优势。列表是可变的,适合存储动态变化的数据;元组是不可变的,适合存储固定的数据。在选择时,我们需要根据具体需求来决定使用哪种数据结构。

(二)字典与集合的选择

字典和集合都基于哈希表实现,具有高效的查找性能。字典适合存储键值对数据,而集合适合存储唯一的数据。在实际应用中,我们可以根据数据的特点和操作需求来选择合适的数据结构。

(三)数据结构的组合使用

在复杂的系统中,我们常常需要组合使用多种数据结构。例如,我们可以使用字典来存储任务的详细信息,同时使用列表来管理任务的顺序。

# 任务管理
tasks = [
    {"name": "侦察敌方基地", "priority": 1, "status": "未完成"},
    {"name": "部署防御系统", "priority": 2, "status": "进行中"},
    {"name": "攻击敌方补给线", "priority": 3, "status": "已完成"}
]

# 任务字典
task_dict = {task["name"]: task for task in tasks}

# 查询任务
print(task_dict["侦察敌方基地"])

七、结语

数据结构是编程的基础,也是解决复杂问题的关键。在 25 世纪的星际时代,数据结构在军事战略中的应用尤为重要。通过合理选择和组合使用数据结构,我们可以提高系统的效率和可维护性,为未来的星际战争做好准备。



http://www.kler.cn/a/524888.html

相关文章:

  • 高级同步工具解析
  • 【每日一A】2015NOIP真题 (二分+贪心) python
  • 算法12(力扣739)-每日温度
  • A7. Jenkins Pipeline自动化构建过程,可灵活配置多项目、多模块服务实战
  • Qt文件操作
  • lightweight-charts-python 包 更新 lightweight-charts.js 的方法
  • 【redis】redis操作zset类型的key发生了什么?
  • 企业知识管理平台助力企业创新与竞争力提升的有效策略探讨
  • 网关登录校验
  • Qwen2.5-max 性能
  • JAVA实战开源项目:网上超市系统(Vue+SpringBoot) 附源码
  • 蓝桥备赛指南(5)
  • TCP 握手数据包分析
  • 「AI学习笔记」深度学习的起源与发展:从神经网络到大数据(二)
  • 【自学笔记】计算机网络的重点知识点-持续更新
  • 格式化时间的插件
  • SET alter system reload
  • 如何看待 OpenAI 的12天“shipmas”发布计划?
  • CTFSHOW-WEB入门-命令执行29-32
  • Linux文件原生操作
  • 【apt源】RK3588 平台ubuntu20.04更换apt源
  • (done) MIT6.S081 2023 学习笔记 (Day6: LAB5 COW Fork)
  • python + ollama 手敲实现私有大模型知识库
  • LeetCode 349题解:两个数组的交集
  • 使用Vue3实现可拖拽的九点导航面板
  • Kafka的消息协议