蓝桥杯【第14届省赛】Python B组

news/2024/5/3 17:58:05/文章来源:https://blog.csdn.net/qq_55745968/article/details/130028407

本题解不一定正确,欢迎大家指正

A:2023

【问题描述】

        请求出在 12345678 至 98765432 中,有多少个数中完全不包含 2023 。

        完全不包含 2023 是指无论将这个数的哪些数位移除都不能得到 2023 。

        例如 20322175,33220022 都完全不包含 2023,而 20230415,20193213 则 含有 2023 (后者取第 1, 2, 6, 8 个数位) 。

【解析及代码】

数据规模也才 1e9 左右,暴力枚举就完了

利用 re 库的正则表达式进行匹配,非常方便,答案:85959030

import repat = re.compile(r'\d*'.join('2023'))
nums = range(12345678, 98765432 + 1)
print(sum(not re.search(pat, i) for i in map(str, nums)))

B:硬币兑换

【问题描述】

        小蓝手中有 2023 种不同面值的硬币,这些硬币全部是新版硬币,其中第 i (1 ≤ i ≤ 2023) 种硬币的面值为 i ,数量也为 i 个。硬币兑换机可以进行硬币兑 换,兑换规则为:交给硬币兑换机两个新版硬币 coin1 和 coin2 ,硬币兑换机会 兑换成一个面值为 coin1 + coin2 的旧版硬币。

        小蓝可以用自己已有的硬币进行任意次数兑换,假设最终小蓝手中有 K 种不同面值的硬币(只看面值,不看新旧)并且第 i (1 ≤ i ≤ K) 种硬币的个数为 sum_i。小蓝想要使得 \max\{sum_1, sum_2, \cdots, sum_K\} 的值达到最大,请你帮他计算 这个值最大是多少。

        注意硬币兑换机只接受新版硬币进行兑换,并且兑换出的硬币全部是旧版硬币。

【解析及代码】

因为只支持新版硬币兑换旧版硬币,所以尽可能地兑换面值 2023 的硬币就行了

总数为:2023 + \frac{(1+1011)\times1011}{2}=513589

# 凑成 2023
cnt = 2023
item = cnt // 2
cnt += (1 + item) * item // 2
# 513589
print(cnt)

C:松散子序列

【问题描述】

        给定一个仅含小写字母的字符串 s ,假设 s 的一个子序列 t 的第 i 个字符 对应了原字符串中的第 p_i 个字符。我们定义 s 的一个松散子序列为:对于 i > 1 总是有 p_i - p_{i-1} \geq 2。设一个子序列的价值为其包含的每个字符的价值之和 (a ∼ z 分别为 1 ∼ 26) 。

        求 s 的松散子序列中的最大价值。

【输入格式】

        输入一行包含一个字符串 s 。

【输出格式】

        输出一行包含一个整数表示答案。

【样例】

输入输出
azaazaz78

【评测用例规模与约定

20%|s| \leq 10
40%|s| \leq 300
70%|s| \leq 5000
100%1 \leq |s| \leq 10^6,字符串中仅包含小写字母

【解析及代码】

先利用 ord 函数,将小写字母转化为 1 ~ 26 的值,记为 value

创建一维列表 dp,以 dp[i] 表示第 i 个字符 (索引从 1 开始) 被包含时,松散子序列的最大价值

然后以 value = [1, 26, 1, 1, 1, 26, 1, 26] 为例:

  • 当第 6 个字符 (第 2 个 26) 被包含时,因为松散子序列的定义有 dp[6] = max(dp[:5]) + 26
  • 然后又因为题目要求的是价值最大的松散子序列,所以被包含的字符之间的空隔不超过 2,此时可以进一步减少计算量,有 dp[6] = max(dp[3: 5]) + 26
value = list(map(lambda s: ord(s) - 96, input()))
# dp[i] 表示第 i 个字符被采用时的最高分数
dp = [0] * (len(value) + 1)
dp[1] = value[0]for i, v in zip(range(2, len(value) + 1), value[1:]):# 找到最优的前置状态: 最优松散子序列中各个数的间隔不超过 2dp[i] = max(dp[max((0, i - 3)): i - 1]) + v
# 最后两个数必有一个被包含
print(max(dp[-2:]))

D:管道

【问题描述】

        有一根长度为 len 的横向的管道,该管道按照单位长度分为 len 段,每一段的中央有一个可开关的阀门和一个检测水流的传感器。

        一开始管道是空的,位于 L_i 的阀门会在 S_i 时刻打开,并不断让水流入管道。

        对于位于 L_i 的阀门,它流入的水在 T_i (T_i \geq S_i) 时刻会使得从第 L_i - (T_i - S_i) 段到第 L_i + (T_i - S_i) 段的传感器检测到水流。

        求管道中每一段中间的传感器都检测到有水流的最早时间。

【输入格式】

        输入的第一行包含两个整数 n, len,用一个空格分隔,分别表示会打开的阀门数和管道长度。

        接下来 n 行每行包含两个整数 L_i, S_i,用一个空格分隔,表示位于第 L_i 段管道中央的阀门会在 S_i 时刻打开。

【输出格式】

        输出一行包含一个整数表示答案。

【样例】

输入输出

3 10

1 1

6 5

10 2

5

【评测用例规模与约定

30%n \leq 200, S_i, len \leq 3000
70%n \leq 5000, S_i, len \leq 10^5
100%1 \leq n \leq 10^5, 1 \leq S_i, len \leq 10^9, 1 \leq L_i \leq len, L_{i-1} < L_i

【解析及代码】

没有什么好的想法,直接暴力

n, length = map(int, input().split())
# 经过的时间 = 扩散的长度
cost = [float('inf')] * length
for _ in range(n):l, s = map(int, input().split())l -= 1for i in range(length):cost[i] = min((cost[i], abs(i - l) + s))
print(max(cost))

E:保险箱

【问题描述】

        小蓝有一个保险箱,保险箱上共有 n 位数字。

        小蓝可以任意调整保险箱上的每个数字,每一次操作可以将其中一位增加 1 或减少 1。

        当某位原本为 9 或 0 时可能会向前(左边)进位/退位,当最高位(左边第 一位)上的数字变化时向前的进位或退位忽略。

        例如:

        00000 的第 5 位减 1 变为 99999 ;

        99999 的第 5 位减 1 变为 99998 ;

        00000 的第 4 位减 1 变为 99990 ;

        97993 的第 4 位加 1 变为 98003 ;

        99909 的第 3 位加 1 变为 00009 。

        保险箱上一开始有一个数字 x,小蓝希望把它变成 y,这样才能打开它,问小蓝最少需要操作的次数。

【输入格式】

        输入的第一行包含一个整数 n 。

        第二行包含一个 n 位整数 x 。

        第三行包含一个 n 位整数 y 。

【输出格式】

        输出一行包含一个整数表示答案。

【样例】

输入输出

5

12349

54321

11

【评测用例规模与约定

30%1 \leq n \leq 300
60%1 \leq n \leq 3000
100%1 \leq n \leq 10^5,x,y 中仅包含数字 0 至 9,可能有前导零

【解析及代码】

F:树上选点

【问题描述】

        给定一棵树,树根为 1,每个点的点权为 V_i

        你需要找出若干个点 P_i,使得:

        1. 每两个点 P_x, P_y 互不相邻;

        2. 每两个点 P_x, P_y 与树根的距离互不相同;

        3. 找出的点的点权之和尽可能大。

        请输出找到的这些点的点权和的最大值。

【输入格式】

        输入的第一行包含一个整数 n 。

        第二行包含 n − 1 个整数 F_i ,相邻整数之间使用一个空格分隔,分别表示第 2 至 n 个结点的父结点编号。

        第三行包含 n 个整数 V_i,相邻整数之间使用一个空格分隔,分别表示每个结点的点权。

【输出格式】

        输出一行包含一个整数表示答案。

【样例】

输入输出

5

1 2 3 2

2 1 9 3 5

11

【评测用例规模与约定

40%n \leq 5000
100%1 \leq n \leq 2 \times 10^5, 1 \leq F_i < i, 1 \leq V_i \leq 10^4

【解析及代码】

编写继承 list 的类 Node,用于存储子结点的序号,并用实例变量 v 记录点权

从根结点出发,搜索并得到各个结点的深度 (即与树根的距离),并根据深度添加到字典 depths

然后在枚举时利用 depths 来使得结点 i 和结点 j 的深度不同,并进一步利用 Node 类判断是否相邻

class Node(list):def __init__(self, v):super().__init__()self.v = vn = int(input())
father = list(map(lambda x: int(x) - 1, input().split()))
nodes = list(map(Node, map(int, input().split())))# 添加子结点
for i, dad in zip(range(1, n + 1), father): nodes[dad].append(i)
# 各个深度的结点的字典
depths = {}
# 使用栈消除递归: 结点序号, 结点深度
stack = [(0, 0)]
while stack:i, depth = stack.pop()depths.setdefault(depth, []).append(i)# 子结点入栈for j in nodes[i]:stack.append((j, depth + 1))ret = 0
for d in depths:# 保证结点 i 和结点 j 的深度不同for i in depths[d]:for j in sum((depths[d_] for d_ in depths if d_ != d), []):# 判断结点是否相邻if i not in nodes[j] and j not in nodes[i]:ret = max((ret, nodes[i].v + nodes[j].v))
print(ret)

G:T 字消除

【问题描述】

        小蓝正在玩一款游戏,游戏中有一个 n × n 大小的 01 矩阵 A_{i, j}

        小蓝每次需要选择一个 T 字型的区域,且这个区域内至少要有一个 1 。选 中后,这个区域内所有的元素都会变成 0 。

        给定游戏目前的矩阵,小蓝想知道他最多可以进行多少次上述操作。

        T 字型区域是指形如 (x − 1, y) (x, y) (x + 1, y) (x, y + 1) 的四个点所形成的区域。其旋转 90, 180, 270 度的形式同样也视作 T 字形区域。

【输入格式】

        输入包含多组数据。

        输入的第一行包含一个整数 D 表示数据组数。

        对于每组数据,第一行包含一个整数 n 。

        接下来 n 行每行包含 n 个 0 或 1,表示矩阵 A_{i,j} 的每个位置的值。

【输出格式】

        输出 D 行,每行包含一个整数表示小蓝最多可以对当前询问中的矩阵操作的次数。

【样例】

输入输出说明

1 3

001

011

111

5

【评测用例规模与约定

10%n=3
40%n \leq 30
100%3 \leq n \leq 2000

【解析及代码】

H:独一无二

【问题描述】

        有一个包含 n 个点,m 条边的无向图,第 i 条边的边权为 c_i,没有重边和自环。设 s_i 表示从结点 1 出发到达结点 i 的最短路的不同路径数 (i ∈ [1, n]), 显然可以通过删除若干条边使得 s_i = 1,也就是有且仅有一条从 1 到 i 的最短 路,且保持最短路的路径长度不变,对于每个 i ,求出删除边数的最小值。

【输入格式】

        输入的第一行包含两个正整数 n, m。 接下来 m 行,每行包含三个正整数 u_i, v_i, c_i 表示第 i 条边连接的两个点的编号和边权。

【输出格式】

        输出 n 行,第 i 行包含一个正整数表示对于结点 i ,删除边数的最小值,如果 1 和 i 不连通,输出 −1 。

【样例】

输入输出说明

4 4

1 2 1

1 3 2

2 4 2

3 4 1

0

0

0

1

在给定的图中,只有 s_4 一开始为 2,

因为有两条最短路:1 → 2 → 4, 1 → 3 → 4,

任意删掉一条边后,就可以只剩一条最短路。

【评测用例规模与约定

30%n \leq 1000
100%n \leq 10^5, 0 \leq m \leq \min\{\frac{n(n-1)}{2}, 10^6\}, 1 \leq u_i, v_i \leq n, 1 \leq c_i \leq 10

【解析及代码】

I:异或和

【问题描述】

        给一棵含有 n 个结点的有根树,根结点为 1 ,编号为 i 的点有点权 a_i (i \in [1, n])。现在有两种操作,格式如下:

  • 1 x y 该操作表示将点 x 的点权改为 y 。
  • 2 x 该操作表示查询以结点 x 为根的子树内的所有点的点权的异或和。

        现有长度为 m 的操作序列,请对于每个第二类操作给出正确的结果。

【输入格式】

        输入的第一行包含两个正整数 n, m ,用一个空格分隔。

        第二行包含 n 个整数 a_1, a_2, \cdots, a_n,相邻整数之间使用一个空格分隔。

        接下来 n − 1 行,每行包含两个正整数 u_i, v_i ,表示结点 u_iv_i 之间有一条边。

        接下来 m 行,每行包含一个操作。

【输出格式】

        输出若干行,每行对应一个查询操作的答案。

【样例】

输入输出

4 4

1 2 3 4

1 2

1 3

2 4

2 1

1 1 0

2 1

2 2

4

5

6

【评测用例规模与约定

30%n,m \leq 1000
100%1 \leq n, m \leq 10^5, 0 \leq a_i, y \leq 10^5, 1 \leq u_i, v_i,x \leq n

【解析及代码】

先看看异或这个操作的特性,比如 7(111) ^ 4(100) = 3(011),3(011) ^ 7(111) = 4(100)

所以,对于一个数组的异或和,如果其中的某一个数值被改变,异或上原来的数值、新的数值即可得到新的异或和

利用这个技巧,可以在初始化的时候预计算所有子树的异或和,并在每次更新点权时更新所有父结点的异或和

定义 Node 类,以存储树结点的信息,并进行异或和的计算:

  • search:因为题目给定的是“边”,所以只能知道每个树结点与哪个结点相连,而不知道父结点;从根结点开始搜索,利用这个函数可以找到所有树结点的父结点,并预计算异或和
  • update:递归函数,给当前结点、所有父结点的异或和异或上参数 v
  • change:调用 update 函数修改异或和,并修改当前结点的 v
class Node:def __init__(self, info):super().__init__()# 父结点, 子结点self.dad = Noneself.vex = set()# 索引, 价值, 子树异或和self.i, self.v = infoself.sum = self.vdef search(self, dad):# 设置父结点self.dad = dadself.vex.remove(dad)# 计算子树异或和for child in self.vex:self.sum ^= nodes[child].search(self.i)delattr(self, 'vex')return self.sumdef change(self, v):self.update(v ^ self.v)self.v = vdef update(self, v):self.sum ^= vif self.dad >= 0:nodes[self.dad].update(v)n, m = map(int, input().split())
nodes = list(map(Node, enumerate(map(int, input().split()))))
# 添加父结点、子结点
for _ in range(n - 1):u, v = map(lambda x: int(x) - 1, input().split())nodes[u].vex.add(v)nodes[v].vex.add(u)
# 查找父结点, 计算异或和
nodes[0].vex.add(-1)
nodes[0].search(-1)
# 开始若干次操作
for _ in range(m):oper, *args = map(int, input().split())if oper == 1:x, y = argsnodes[x - 1].change(y)else:print(nodes[args[0] - 1].sum)

J:混乱的数组

【问题描述】

        给定一个正整数 x,请找出一个尽可能短的仅含正整数的数组 A 使得 A 中 恰好有 x 对 i, j 满足 A_i > A_j。 如果存在多个这样的数组,请输出字典序最小的那个。

【输入格式】

        输入一行包含一个整数表示 x 。

【输出格式】

        输出两行。

        第一行包含一个整数 n ,表示所求出的数组长度。

        第二行包含 n 个整数 A_i,相邻整数之间使用一个空格分隔,依次表示数组中的每个数。

【样例】

输入输出

3

3

3 2 1

【评测用例规模与约定

30%x \leq 10
60%x \leq 100
100%1 \leq x \leq 10^9

【解析及代码】

题目不是很完整的样子,需要我们自行推导一下附加条件

根据样例可知,[3 2 1] 包含 3 对 A_i > A_j,而且 i < j

显然可得,长度为 n、元素从 n 到 1 的正整数数组可以提供的“对”数为:\frac{(n-1)n}{2} \geq x

那么可解得 n = \left \lceil \sqrt{2x+\frac{1}{4}}+\frac{1}{2} \right \rceil,对于 x = 11,该数组就为 [6 5 4 3 2 1]

上述数组实际提供的“对”数为 15,溢出的 4 对可以通过减小数组的值抹去

根据题目要求的“字典序最小”,所以应该减小数组的第一个数值,最终结果为 [2 5 4 3 2 1]

import mathx = int(input())
# (n - 0.5) ^ 2 = 2x + 0.25
n = math.ceil(math.sqrt(2 * x + 0.25) + 0.5)
array = list(range(n, 0, -1))cur = (n - 1) * n // 2
# 除去溢出的 "对"
array[0] -= cur - x
print(n)
print(*array)

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

如若内容造成侵权/违法违规/事实不符,请联系dt猫网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

python实现获取当前目录下的树形结构

python实现获取当前目录下的树形结构 程序实现 在有些Linux上自带了tree命令来一树状结构显示一个目录&#xff0c;但是在有些linux上没有自带这个程序&#xff0c;所以这里用python写了一个小程序来实现这个功能&#xff0c;代码如下&#xff1a; import osdef print_tree(…

共模电感(扼流圈) 差模电感(扼流圈)

共模电感 共模电感&#xff0c;也叫共模扼流圈。常用于电脑的开关电源&#xff0c;过滤共模的电磁干扰信号。 共模电感器由软磁铁芯&#xff08;铁氧体磁芯&#xff09;和两组同相绕制的线圈组成。对于共模信号&#xff0c;由于两组线圈产生的磁场不是抵消。而是相互叠加&…

存量市场之下,电商之战深入腹地且逻辑未变

纵然是在流量依然见顶的大背景下&#xff0c;电商行业的竞争并未结束。无论是以百亿补贴为代表的烧钱策略&#xff0c;还是以跨境出海为代表的规模策略&#xff0c;几乎都是这样一种现象的直接体现。种种迹象表明&#xff0c;未来的电商行业&#xff0c;依然会有新的战役发生。…

Hadoop集群环境搭建与应用回顾

文章目录一、 实训项目名称二、 学习情况小结三、 项目中用到的知识点四、 实训项目中负责功能板块五、 实训项目实现六、 实训项目过程中遇到的问题及解决方法七、实训体会与心得一、 实训项目名称 Hadoop集群环境搭建与应用 二、 学习情况小结 实操一部分&#xff1a; 通…

linux 服务器 docker 安装 nacos 2.0.3

docker 镜像 https://registry.hub.docker.com/r/nacos/nacos-server/tags 1.下载nacos镜像 这里下载的是2.0.3 docker pull nacos/nacos-server:2.0.32.查看镜像是否下载成功 如下图 docker images3.创建文件夹 注&#xff1a; 自定义创建&#xff0c;用于把docker内部的文件…

【基金学习】基金的相关计算题目

文章目录一、基金收益计算1. 累计收益/持有收益2. 年化收益/年化收益率3. 涨跌幅4. 分红二、风险计算1. 贝塔系数2. 波动率三、费用计算1. 托管费2. 管理费3. 销售服务费4. 申购/赎回费一、基金收益计算 1. 累计收益/持有收益 累计收益 持仓金额 - 本金 累计收益率 &#xf…

TCP 的 NACK 与 SACK

可靠传输&#xff0c;一旦丢包&#xff0c;必然 HoL blocking&#xff0c;NACK 和 SACK 必须二选一驱动重传&#xff1a; NACK&#xff1a;receiver 主动通告没有收到的报文&#xff0c;sender 收到后重传。 SACK&#xff1a;receiver 主动通告收到的报文&#xff0c;sender …

一文带你深入了解算法笔记中的前缀与差分(附源码)

&#x1f4d6;作者介绍&#xff1a;22级树莓人&#xff08;计算机专业&#xff09;&#xff0c;热爱编程&#xff1c;目前在c&#xff0b;&#xff0b;阶段&#xff0c;因为最近参加新星计划算法赛道(白佬)&#xff0c;所以加快了脚步&#xff0c;果然急迫感会增加动力>——…

笔记本上就能跑的 LLM 好使吗?GPT4ALL 体验

是骡子是马&#xff0c;牵出来遛遛正名看到这个标题&#xff0c;你可能会觉得是噱头。谁不知道 ChatGPT 模型有 1750 亿以上的参数&#xff0c;别说是在笔记本电脑上跑&#xff0c;就是使用高性能 GPU 的台式机&#xff0c;也无法带得动啊。老老实实调用 API 不好吗&#xff1f…

torchvision.transforms 常用方法解析(含图例代码以及参数解释)

本文代码和图片完全源于 官方文档: TRANSFORMING AND AUGMENTING IMAGES 中的 Illustration of transforms&#xff0c;参数介绍源自函数对应的官方文档。 代码中的变换仅仅使用了最简单的参数&#xff1a;pad&#xff0c;size 等&#xff0c;这里展现的只是简单的变换&#xf…

中间表示- 数据流分析

数据流分析往往与优化绑定在一起&#xff0c;如下图所示。 优化的一般模式 程序分析 &#xff08;1&#xff09;控制流分析、数据流分析、依赖分析等。 &#xff08;2&#xff09;得到被优化程序的静态保守信息&#xff0c;是对动态运行行为的近似。 程序重写 以上一步得到…

用于3D分子生成的等变扩散模型ICML2022

现代深度学习方法开始对分子科学产生重要影响。在Alphafold在蛋白质折叠预测方面取得成功的背后&#xff0c;越来越多的工作开发了深度学习模型来分析或合成分子。分子存在于物理3D空间中&#xff0c;因此受制于几何对称性&#xff0c;如平移、旋转。这些对称性被称为三维欧几里…

Compose(?/N) - 标准布局

组合函数不指定布局默认是Box堆叠。 一、纵向 Colum inline fun Column( modifier Modifier, verticalArrangement Arrangement.Top, //子元素纵向排列规则 horizontalAlignment Alignment.Start, //子元素横向排列规则 content: Composable ColumnScope.() -…

蓝桥杯基础12:BASIC-3试题 字母图形

资源限制 内存限制&#xff1a;256.0MB C/C时间限制&#xff1a;1.0s Java时间限制&#xff1a;3.0s Python时间限制&#xff1a;5.0s 问题描述 利用字母可以组成一些美丽的图形&#xff0c;下面给出了一个例子&#xff1a; ABCDEFG BABCDEF CBABCDE DCBABCD EDC…

【设计模式】设计模式概述以及UML图

设计模式概述以及UML图设计模式概述1. 设计模式的概念2. 学习设计模式的必要性3. 设计模式的分类UML图1. 什么是UML图2. 类图的概念和作用3. 类图的表示法4. 类与类之间的表示方式4.1 关联关系4.2 聚合关系4.3 组合关系4.4 依赖关系4.5 继承关系4.6 实现关系设计模式概述 1. 设…

工作面试老大难-MySQL中的锁类型

MySQL 是支持ACID特性的数据库。我们都知道”C”代表Consistent&#xff0c;当不同事务操作同一行记录时&#xff0c;为了保证一致性&#xff0c;需要对记录加锁。在MySQL 中&#xff0c;不同的引擎下的锁行为也会不同&#xff0c;本文将重点介绍 MySQL InnoDB引擎中常见的锁。…

卷,卷,卷,SAM发布不到24h | BAAI、浙大、北大联合推出SegGPT

CV - 计算机视觉 | ML - 机器学习 | RL - 强化学习 | NLP 自然语言处理 昨天都被Meta的SAM模型刷屏了吧&#xff01;但在其发布24h不到&#xff01; 北京智源人工智能研究院联合浙大、北大发布SegGPT: Segmenting Everything In Context。让我们来一探究竟。 我们提出了SegGPT…

一文详解 unversioned files 怎么处理

通常unversioned files下面都是.idea文件&#xff0c;而.idea文件我们在做提交的时候基本上是不需要提交到gitee或github上的&#xff0c;所以我们可以把.idea文件忽略掉从而解决unversioned files里多余的文件&#xff0c;只专注于提交我们写的代码 找到.gitignore 打开后&a…

【Linux】一篇文章, 掌握Linux进程信号

文章目录进程信号介绍进程信号进程信号的处理signal() 捕捉信号用户层产生进程信号的方式键盘产生进程信号系统调用产生进程信号kill()raise()abort()软件条件产生进程信号硬件异常产生进程信号除0 和 越界访问、野指针 如何产生相应信号除0越界访问、野指针core dumpcore 文件…

Python3入门教程||Python3 正则表达式||Python3 CGI 编程

Python3 正则表达式 在 Python3 中正则表达式是一个特殊的字符序列&#xff0c;它能帮助你方便的检查一个字符串是否与某种模式匹配。 Python 自1.5版本起增加了re 模块&#xff0c;它提供 Perl 风格的正则表达式模式。 re 模块使 Python 语言拥有全部的正则表达式功能。 c…