文章目录
第十一届蓝桥杯省赛C++ B组(7.25)
A:跑步训练
题意:
本题总分:5 分
【问题描述】
小明要做一个跑步训练。
初始时,小明充满体力,体力值计为 10000。如果小明跑步,每分钟损耗
600 的体力。如果小明休息,每分钟增加 300 的体力。体力的损耗和增加都是
均匀变化的。
小明打算跑一分钟、休息一分钟、再跑一分钟、再休息一分钟……如此循
环。如果某个时刻小明的体力到达 0,他就停止锻炼。
请问小明在多久后停止锻炼。为了使答案为整数,请以秒为单位输出答案。
答案中只填写数,不填写单位。
【答案提交】
这是一道结果填空题,你只需要算出结果后提交即可。本题的结果为一个
整数,在提交答案时只填写这个整数,填写多余的内容将无法得分。
**题解:**3880。直接笔算即可:10000-300*32=400,32 * 2 * 60 + 40 = 3880
代码: 无
B.纪念日
题意:
本题总分:5 分
【问题描述】
2020 年 7 月 1 日是***(敏感字)成立 99 周年纪念日。
***(敏感字)成立于 1921 年 7 月 23 日。
请问从 1921 年 7 月 23 日中午 12 时到 2020 年 7 月 1 日中午 12 时一共包含多少分钟?
【答案提交】
这是一道结果填空题,你只需要算出结果后提交即可。本题的结果为一个
整数,在提交答案时只填写这个整数,填写多余的内容将无法得分。
题解: 52,038,720。excel解即可。
代码: 无
C: 合并检测
题意:
本题总分:10 分
【问题描述】
***(敏感字)由 ***(敏感字)引起,最近在 A 国蔓延,为了尽快控制 ***(敏感字),A 国准备给大量民众进病毒核酸检测。然而,用于检测的试剂盒紧缺。为了解决这一困难,科学家想了一个办法:合并检测。即将从多个人(k个)采集的标本放到同一个试剂盒中进行检测。如果结果为阴性,则说明这 k个人都是阴性,用一个试剂盒完成了 k 个人的检测。如果结果为阳性,则说明至少有一个人为阳性,需要将这 k 个人的样本全部重新独立检测(从理论上看,如果检测前 k 1 个人都是阴性可以推断出第 k 个人是阳性,但是在实际操作中不会利用此推断,而是将 k 个人独立检测),加上最开始的合并检测,一共使用了 k + 1 个试剂盒完成了 k 个人的检测。A 国估计被测的民众的感染率大概是 1%,呈均匀分布。请问 k 取多少能最节省试剂盒?
【答案提交】
这是一道结果填空题,你只需要算出结果后提交即可。本题的结果为一个
整数,在提交答案时只填写这个整数,填写多余的内容将无法得分。
题解: 10。假设有100人,那么需要试剂的数目: s u m = 100 k + k sum = \frac{100}{k} + k sum=k100+k,对勾函数 k 2 = = 100 k^2 == 100 k2==100时取得最小值。k=10。
**代码:**无
D: REPEAT 程序
题意:
本题总分:10 分
【问题描述】
附件 prog.txt 中是一个用某种语言写的程序。
其中 REPEAT k 表示一个次数为 k 的循环。循环控制的范围由缩进表达,
从次行开始连续的缩进比该行多的(前面的空白更长的)为循环包含的内容。
例如如下片段:
REPEAT 2:
A = A + 4
REPEAT 5:
REPEAT 6:
A = A + 5
A = A + 7
A = A + 8
A = A + 9
该片段中从 A = A + 4 所在的行到 A = A + 8 所在的行都在第一行的循环两次中。
REPEAT 6: 所在的行到 A = A + 7 所在的行都在 REPEAT 5: 循环中。A = A + 5 实际总共的循环次数是 2 × 5 × 6 = 60 次。
请问该程序执行完毕之后,A 的值是多少?
【答案提交】
这是一道结果填空题,你只需要算出结果后提交即可。本题的结果为一个
整数,在提交答案时只填写这个整数,填写多余的内容将无法得分。
**题解:**241830。缩进的样子正适合python,直接使用ctrl+H对REPEAT k 进行替换为: for i in range(k),然后跑python即可。
代码: 略
E: 矩阵
题意:
本题总分:15 分
【问题描述】
把 1 ∼ 2020 放在 2 × 1010 的矩阵里。要求同一行中右边的比左边大,同一
列中下边的比上边的大。一共有多少种方案?
答案很大,你只需要给出方案数除以 2020 的余数即可。
【答案提交】
这是一道结果填空题,你只需要算出结果后提交即可。本题的结果为一个
整数,在提交答案时只填写这个整数,填写多余的内容将无法得分。
题解: 1340。这题进阶指南里杨老师的照相排列类似,是个经典的模型。
f [ i ] [ j ] f[i][j] f[i][j]:表示第1行方i个人,第2行方j个人。
状态转移使用最后一个人的位置划分。为了保证左上角更大,右下角更小这个性质,分析可以知道前面已经排列好的数字一定是连续的,因此对于 f [ i ] [ j ] f[i][j] f[i][j]的子状态只有 f [ i − 1 ] [ j ] ( 最 后 一 个 人 放 在 第 1 列 的 最 后 一 个 位 置 ) f[i-1][j](最后一个人放在第1列的最后一个位置) f[i−1][j](最后一个人放在第1列的最后一个位置), f [ i ] [ j − 1 ] ( 最 后 一 个 人 放 在 第 2 列 的 最 后 一 个 位 置 ) f[i][j-1](最后一个人放在第2列的最后一个位置) f[i]