Python 标准库与数据结构

devtools/2025/3/29 3:46:17/

python">Python的标准库提供了丰富的内置数据结构和函数,使用这些工具能为我们提供一套强有力的工具。

需要注意的是,相比C++与Java,Python的一些特点:

  1. Python不需要显式声明变量类型
  2. Python没有模板(Template)的概念,因为Python是动态类型语言
  3. Python的标准库导入更简单,只需要 import 相关模块即可

我们主要介绍以下几种数据结构:

  • list:列表
  • set:集合
  • dict:字典
  • queue 和 deque:队列
  • heapq:堆

如果在比赛的过程中,忘记了某些函数的使用或者拼写,可能查看比赛机器桌面上的手册,会有这些函数的具体使用方法。

1. 迭代器说明

在Python中,迭代器的概念比C++更简单。所有的Python集合都是可迭代的,不需要显式声明迭代器。我们可以直接使用for循环进行遍历:

numbers = [1, 2, 3, 4, 5]
for num in numbers:print(num)  # 输出: 1 2 3 4 5# 如果需要索引,可以使用enumerate
for index, num in enumerate(numbers):print(f"索引 {index}: {num}")

2. 数据结构详解

2.1 list(列表)

list是Python中最基础的序列数据结构,本身则就具有可变数组的能力。

基本操作:

# 创建列表
lst = []                  # 创建空列表
lst = [1, 2, 3]          # 创建包含元素的列表
lst = [0] * 5            # 创建长度为5的列表,所有元素为0# 常用操作
lst.append(x)            # 在末尾添加元素x
lst.pop()               # 删除并返回末尾元素
lst.pop(i)              # 删除并返回索引i处的元素
lst.insert(i, x)        # 在索引i处插入元素x
len(lst)                # 返回列表长度
lst[i]                  # 访问第i个元素

例子:

numbers = []
numbers.append(1)    # numbers = [1]
numbers.append(2)    # numbers = [1, 2]
numbers.append(3)    # numbers = [1, 2, 3]
print(len(numbers))  # 输出: 3
numbers.pop()        # numbers = [1, 2]

2.2 set(集合)

set是Python中的无序不重复元素集合,实现方式是哈希表,而不是C++中的红黑树。这意味着Python的set操作复杂度是O(1),而不是O(log n)。

基本操作:

s = set()               # 创建空集合
s.add(x)               # 添加元素x
s.remove(x)            # 删除元素x(元素不存在会报错)
s.discard(x)           # 删除元素x(元素不存在不会报错)
len(s)                 # 返回元素个数
x in s                 # 检查元素是否在集合中

例子:

s = set()
s.add(3)      # s = {3}
s.add(1)      # s = {1, 3}
s.add(2)      # s = {1, 2, 3}
s.add(2)      # s仍然是{1, 2, 3}
print(2 in s)  # 输出: True

2.3 dict(字典)

dict是Python中的键值对容器,同样基于哈希表实现,操作复杂度是O(1)。

基本操作:

d = {}                 # 创建空字典
d[key] = value        # 添加或更新键值对
d.pop(key)            # 删除并返回键对应的值
len(d)                # 返回键值对数量
key in d              # 检查键是否存在

例子:

scores = {}
scores["Alice"] = 95    # 记录Alice的分数
scores["Bob"] = 89      # 记录Bob的分数
print(scores["Alice"])  # 输出: 95

2.4 queue和deque(队列)

Python提供了collections.deque作为双端队列实现,功能比C++的queue更强大。

from collections import deque# 基本操作
q = deque()           # 创建空队列
q.append(x)           # 在右侧添加元素
q.appendleft(x)       # 在左侧添加元素
q.pop()               # 删除并返回右侧元素
q.popleft()           # 删除并返回左侧元素
len(q)                # 返回元素个数

例子:

from collections import deque
q = deque()
q.append(1)     # q = deque([1])
q.append(2)     # q = deque([1, 2])
q.append(3)     # q = deque([1, 2, 3])
print(q[0])     # 输出: 1
q.popleft()     # q = deque([2, 3])

2.5 heapq(堆)

Python通过heapq模块提供堆的功能,默认是小根堆(最小元素在顶部),注意,该模块使用需要一个容器来进行操作。

基本操作:

import heapqheap = []               # 创建空列表作为堆
heapq.heappush(heap, x) # 将元素x压入堆
heapq.heappop(heap)     # 弹出并返回最小元素
heap[0]                 # 查看最小元素
len(heap)               # 返回元素个数

例子:

import heapqheap = []
heapq.heappush(heap, 3)  # heap = [3]
heapq.heappush(heap, 1)  # heap = [1, 3]
heapq.heappush(heap, 4)  # heap = [1, 3, 4]
print(heap[0])           # 输出: 1(最小元素)

3. 补充说明-关于有序集合

Python的set和dict不支持像C++那样的二分查找API(lower_bound、upper_bound),因为它们是基于哈希表实现的。在python组的题目中,也基本不会出现相关的题。

5. 实践与例题

5.1 真题-连连看

很明显,需要求的是每条对角线上的相同数值的对数,如下图:

我们可以枚举每一条45度角对角线,然后进行从上到下、或是从下到上进行遍历,一边遍历一边记录当前数值的数量即可,使用map 进行维护:

def get_l(x, y):global ansmp = {}while x <= n and y <= m:if a[x][y] not in mp:mp[a[x][y]] = 0ans += mp[a[x][y]]  mp[a[x][y]] += 1x += 1y += 1def get_r(x, y):global ansmp = {}while x > 0 and y <= m:if a[x][y] not in mp:mp[a[x][y]] = 0ans += mp[a[x][y]]  # 当 key 不存在 mp 中时,默认值为 0mp[a[x][y]] += 1x -= 1y += 1n, m = map(int, input().split())
a = [[0] * (m + 1) for _ in range(n + 1)]  # 创建二维数组 a,索引从 1 开始
ans = 0# 读取输入
for i in range(1, n + 1):a[i] = [0] + list(map(int, input().split()))  # 读取每一行,并加上前导零,保持从索引 1 开始# 遍历处理主对角线和另外一条对角线
for i in range(1, n + 1):get_l(i, 1)  # 处理主对角线get_r(i, 1)  # 处理另外一条对角线for i in range(2, m + 1):get_l(1, i)get_r(n, i)print(ans * 2)

5.2 哈希表的实现-set

我们直接使用 set 即可

n = int(input())  # 读取输入的整数 n
st = set()  # 创建一个空的集合for _ in range(n):opt, m = input().split()  # 读取操作符和整数 mm = int(m)  # 将 m 转换为整数if opt == 'I':  # 如果操作符是 'I',则插入元素 mst.add(m)elif m not in st:  # 如果操作符不是 'I' 且 m 不在集合中print("No")else:print("Yes")

5.3 堆与优先队列

我们使用优先队列解决:

import heapqn = int(input())  # 读取操作次数 n
pq = []  # 使用列表来模拟小根堆for _ in range(n):op = input().split()  # 读取操作符if op[0] == "push":x = int(op[1])heapq.heappush(pq, x)  # elif op[0] == "remove":if not pq:print("empty")else:heapq.heappop(pq)  # 弹出堆顶元素elif op[0] == "min":if not pq:print("empty")else:print(pq[0])  # 输出堆顶元素elif op[0] == "print":k = int(op[1])if 0 < k <= len(pq):temp = []for _ in range(k):temp.append(pq[0])  # 获取堆顶元素heapq.heappop(pq)  # 弹出堆顶元素print(*temp)  # 打印出来

5.4 小蓝的图书馆

题,要求我们,每一个作者对应一个书的列表,我们可能使用map,同时套上vector。

mp = {}n = int(input())  # 读取操作次数 nfor _ in range(n):arg = input().split()  # 读取操作指令if arg[0] == "add":book, au = arg[1], arg[2]  # 读取书名和作者if au not in mp:mp[au] = []mp[au].append(book)  # 将书名添加到对应作者的列表中else:au = arg[1]  # 读取作者名if au not in mp:mp[au] = []print(len(mp[au]))  # 输出该作者的书籍数量

http://www.ppmy.cn/devtools/171374.html

相关文章

JVM方法区深度解析

方法区&#xff08;Method Area&#xff09;深度解析 1. 方法区的本质 方法区是JVM规范中定义的逻辑内存区域&#xff0c;用于存储类元数据、常量池、静态变量、即时编译器编译后的代码等数据。其核心特点是&#xff1a; 线程共享&#xff1a;所有线程均可访问方法区的数据。生…

【精心整理】2025 DeepSeek 精品学习资料合集-共50份(教程+原理解读+行业应用+技术实践).zip

2025 DeepSeek 精品技术资料合集&#xff0c;包含技术报告、使用教程、原理解读、行业应用、模型部署、开发实战、科研赋能、职场应用、创业机会、AIGC结合、数据资产管理和市场分析等多个方面。 1-DeepSeekR1技术报告_22页.pdf 2-DeepSeekV3技术报告_53页.pdf 3-DeepSeek与AI…

Windows 下使用 Docker 部署 Go 应用与 Nginx 详细教程

一、环境准备 1. 安装必要软件 Docker Desktop for Windows 下载地址&#xff1a;Docker Desktop: The #1 Containerization Tool for Developers | Docker 安装时勾选"使用 WSL 2 引擎"&#xff08;推荐&#xff09; WSL 2&#xff08;Windows Subsystem for Li…

Python 3.8 Requests 爬虫教程(2025最新版)

遵守网站的爬虫规则、避免爬取敏感信息、保护个人隐私&#xff01; 一、环境配置与基础验证 # 验证 Python 版本&#xff08;需 ≥3.8&#xff09; import sys print(sys.version) # 应输出类似 3.8.12 的信息# 安装 requests 库&#xff08;若未安装&#xff09; # 命令行执…

洛谷: P1443 马的遍历

原题地址:P1443 马的遍历 - 洛谷 题目描述 有一个 nm 的棋盘&#xff0c;在某个点 (x,y) 上有一个马&#xff0c;要求你计算出马到达棋盘上任意一个点最少要走几步。 输入格式 输入只有一行四个整数&#xff0c;分别为 n,m,x,y。 输出格式 一个 nm 的矩阵&#xff0c;代表…

html和css 实现元素顺时针旋转效果(椭圆形旋转轨迹)

一 实现效果 二 实现代码 我自己是用react写的。 1. react 代码如下&#xff1a; import React from "react"; import styles from "./index.less";export default () > {return <div className{styles.containers}><div className{styles.c…

MySQL:数据库基础

数据库基础 1.什么是数据库&#xff1f;2.为什么要学习数据库&#xff1f;3.主流的数据库&#xff08;了解&#xff09;4.服务器&#xff0c;数据库&#xff0c;表之间的关系5.数据的逻辑存储6.MYSQL架构7.存储引擎 1.什么是数据库&#xff1f; 数据库(Database,简称DB)&#x…

RabbitMQ的高级特性介绍(二)

发送方确认 当消息的⽣产者将消息发送出去之后&#xff0c;消息到底有没有正确地到达服务器呢? 如果在消息到 达服务器之前已经丢失(比如RabbitMQ重启, 那么RabbitMQ重启期间⽣产者消息投递失败), 持久化操作也解决不了这个问题&#xff0c;因为消息根本没有到达服务器&#…