第十二届蓝桥杯大赛软件赛省赛 C/C++ 大学 C 组第一场

第十二届蓝桥杯大赛软件赛省赛 C/C++ 大学 C 组第一场部分题解

蓝桥杯再也不是暴力杯了,dp题太绝了做的怀疑人生。

试题 A: ASC

本题总分:5 分
【问题描述】
已知大写字母 A 的 ASCII 码为 65,请问大写字母 L 的 ASCII 码是多少?

76

试题 B: 空间

本题总分:5 分
【问题描述】
小蓝准备用 256MB 的内存空间开一个数组,数组的每个元素都是 32 位
二进制整数,如果不考虑程序占用的空间和维护内存需要的辅助空间,请问
256MB 的空间可以存储多少个 32 位二进制整数?

67108864

 256*1024*1024/4

试题 C: 卡片

本题总分:10 分
【问题描述】
小蓝有很多数字卡片,每张卡片上都是数字 0 到 9。
小蓝准备用这些卡片来拼一些数,他想从 1 开始拼出正整数,每拼一个,
就保存起来,卡片就不能用来拼其它数了。
小蓝想知道自己能从 1 拼到多少。
例如,当小蓝有 30 张卡片,其中 0 到 9 各 3 张,则小蓝可以拼出 1 到 10,
但是拼 11 时卡片 1 已经只有一张了,不够拼出 11。
现在小蓝手里有 0 到 9 的卡片各 2021 张,共 20210 张,请问小蓝可以从 1
拼到多少?

3181

#include<iostream>
#include<cstdio>
#include<cmath>
using namespace std;
int main(){
	int a[11];
	for(int i=0;i<=10;i++){
		a[i]=0;
	}
	int ans=1,k,p,f=0;
	int n;
	cin>>n;
	while(a[0]<=n&&a[1]<=n&&a[2]<=n&&a[3]<=n&&a[4]<=n&&a[5]<=n&&a[6]<=n
	&&a[7]<=n&&a[8]<=n&&a[9]<=n){
			k=ans;
			while(k){
				p=k%10;
				if(a[p]+1>n){
					f=1;
					ans--;
					break;
				}
				a[p]++;
				k/=10;
			}
			if(f){
				break;
			}
			ans++;
	}
	cout<<ans<<endl;
}

试题 D: 相乘

本题总分:10 分
【问题描述】
小蓝发现,他将 1 至 1000000007 之间的不同的数与 2021 相乘后再求除以
1000000007 的余数,会得到不同的数。
小蓝想知道,能不能在 1 至 1000000007 之间找到一个数,与 2021 相乘后
再除以 1000000007 后的余数为 999999999。如果存在,请在答案中提交这个数;
如果不存在,请在答案中提交 0。
【答案提交】
这是一道结果填空的题,你只需要算出结果后提交即可。本题的结果为一
个整数,在提交答案时只填写这个整数,填写多余的内容将无法得分。

17812964

#include<iostream>
#include<cstdio>
#include<cmath>
using namespace std;
int main(){
	long long n=pow(2,10);
	long long k;
	for(long long i=1;i<=1000000007;i++){
		if((i*2021)%1000000007==999999999){
			cout<<i<<endl;
			k=i;
			break;
		}
	}
	return 0;
}

试题 E: 路径

本题总分:15 分
【问题描述】
小蓝学习了最短路径之后特别高兴,他定义了一个特别的图,希望找到图
中的最短路径。
小蓝的图由 2021 个结点组成,依次编号 1 至 2021。
对于两个不同的结点 a, b,如果 a 和 b 的差的绝对值大于 21,则两个结点
之间没有边相连;如果 a 和 b 的差的绝对值小于等于 21,则两个点之间有一条
长度为 a 和 b 的最小公倍数的无向边相连。
例如:结点 1 和结点 23 之间没有边相连;结点 3 和结点 24 之间有一条无
向边,长度为 24;结点 15 和结点 25 之间有一条无向边,长度为 75。
请计算,结点 1 和结点 2021 之间的最短路径长度是多少。
提示:建议使用计算机编程解决问题。
【答案提交】
这是一道结果填空的题,你只需要算出结果后提交即可。本题的结果为一
个整数,在提交答案时只填写这个整数,填写多余的内容将无法得分。

10266837
思路:最短路径

#include <iostream>
using namespace std;
long long gcd(long long a, long long b) {
	return b ? gcd(b, a % b) : a;
}
long long lcm(long long a, long long b) {
	return a / gcd(a, b) * b;
}
long long dis[2025][2025];
int main() {
	memset(dis, 0x3f, sizeof dis);
	for (int i = 1; i <= 2021; ++i) {
		for (int j = i + 1; j <= 2021; ++j) {
			if (j - i <= 21) {
				dis[i][j] = min(lcm(i, j), dis[i][j]);
				dis[j][i] = min(lcm(j, i), dis[j][i]);
			}
			else {
				break;
			}
		}
	}
	for (int i = 1; i <= 2021; ++i) {
		for (int j = 1; j <= 2021; ++j) {
			for (int k = 1; k <= 2021; ++k) {
				dis[i][k] = min(dis[i][k], dis[i][j] + dis[j][k]);
			}
		}
	}
	cout << dis[1][2021] << endl;
}

试题 F: 时间显示

时间限制: 1.0s 内存限制: 256.0MB 本题总分:15 分
【问题描述】
小蓝要和朋友合作开发一个时间显示的网站。在服务器上,朋友已经获取
了当前的时间,用一个整数表示,值为从 1970 年 1 月 1 日 00:00:00 到当前时
刻经过的毫秒数。
现在,小蓝要在客户端显示出这个时间。小蓝不用显示出年月日,只需要
显示出时分秒即可,毫秒也不用显示,直接舍去即可。
给定一个用整数表示的时间,请将这个时间对应的时分秒输出。
【输入格式】
输入一行包含一个整数,表示时间。
【输出格式】
输出时分秒表示的当前时间,格式形如 HH:MM:SS,其中 HH 表示时,值
为 0 到 23,MM 表示分,值为 0 到 59,SS 表示秒,值为 0 到 59。时、分、秒
不足两位时补前导 0。

【样例输入 1】

46800999

【样例输出 1】

13:00:00

【样例输入 2】

1618708103123

【样例输出 2】

01:08:23

【评测用例规模与约定】
对于所有评测用例,给定的时间为不超过 10 18 的正整数。

#include<iostream>
#include<cstdio>

using namespace std;
int main(){
	long long n;
	while(scanf("%lld",&n)!=EOF){
		long long hh=n/1000/60/60%60;
		long long mm=n/1000/60%60;
		long long ss=n/1000%60;
		printf("%02lld:%02lld:%02lld\n",hh,mm,ss);
	}
}

试题 G: 最少砝码

时间限制: 1.0s 内存限制: 256.0MB 本题总分:20 分
【问题描述】
你有一架天平。现在你要设计一套砝码,使得利用这些砝码可以称出任意
小于等于 N 的正整数重量。
那么这套砝码最少需要包含多少个砝码?
注意砝码可以放在天平两边。
【输入格式】
输入包含一个正整数 N。
【输出格式】
输出一个整数代表答案。

【样例输入】

7

【样例输出】

3

【样例说明】

3 个砝码重量是 1、4、6,可以称出 1 至 7 的所有重量。
1 = 1;
2 = 6 − 4 (天平一边放 6,另一边放 4);
3 = 4 − 1;
4 = 4;
试题 G: 最少砝码 9
第十二届蓝桥杯大赛软件赛省赛 C/C++ 大学 C 组
5 = 6 − 1;
6 = 6;
7 = 1 + 6;
少于 3 个砝码不可能称出 1 至 7 的所有重量。

【评测用例规模与约定】
对于所有评测用例,1 ≤ N ≤ 1000000000。


试题 H: 杨辉三角形

时间限制: 1.0s 内存限制: 256.0MB 本题总分:20 分
【问题描述】
下面的图形是著名的杨辉三角形:
如果我们按从上到下、从左到右的顺序把所有数排成一列,可以得到如下
数列:
1, 1, 1, 1, 2, 1, 1, 3, 3, 1, 1, 4, 6, 4, 1, …
给定一个正整数 N,请你输出数列中第一次出现 N 是在第几个数?
【输入格式】
输入一个整数 N。
【输出格式】
输出一个整数代表答案。

【样例输入】

6

【样例输出】

13
试题 H: 杨辉三角形 11
第十二届蓝桥杯大赛软件赛省赛 C/C++ 大学 C 组
【评测用例规模与约定】
对于 20% 的评测用例,1 ≤ N ≤ 10;
对于所有评测用例,1 ≤ N ≤ 1000000000。


试题 I: 左孩子右兄弟

时间限制: 1.0s 内存限制: 256.0MB 本题总分:25 分
【问题描述】
对于一棵多叉树,我们可以通过 “左孩子右兄弟” 表示法,将其转化成一棵
二叉树。
如果我们认为每个结点的子结点是无序的,那么得到的二叉树可能不唯一。
换句话说,每个结点可以选任意子结点作为左孩子,并按任意顺序连接右兄弟。
给定一棵包含 N 个结点的多叉树,结点从 1 至 N 编号,其中 1 号结点是
根,每个结点的父结点的编号比自己的编号小。请你计算其通过 “左孩子右兄
弟” 表示法转化成的二叉树,高度最高是多少。注:只有根结点这一个结点的
树高度为 0 。
例如如下的多叉树:
可能有以下 3 种 (这里只列出 3 种,并不是全部) 不同的 “左孩子右兄弟”
表示:
试题 I: 左孩子右兄弟 13
第十二届蓝桥杯大赛软件赛省赛 C/C++ 大学 C 组
其中最后一种高度最高,为 4。
【输入格式】
输入的第一行包含一个整数 N。
以下 N −1 行,每行包含一个整数,依次表示 2 至 N 号结点的父结点编号。
【输出格式】
输出一个整数表示答案。

【样例输入】

5
1
1
1
2

【样例输出】

4
试题 I: 左孩子右兄弟 14
第十二届蓝桥杯大赛软件赛省赛 C/C++ 大学 C 组
【评测用例规模与约定】
对于 30% 的评测用例,1 ≤ N ≤ 20;
对于所有评测用例,1 ≤ N ≤ 100000。


试题 J: 括号序列

时间限制: 1.0s 内存限制: 256.0MB 本题总分:25 分
【问题描述】
给定一个括号序列,要求尽可能少地添加若干括号使得括号序列变得合法,
当添加完成后,会产生不同的添加结果,请问有多少种本质不同的添加结果。
两个结果是本质不同的是指存在某个位置一个结果是左括号,而另一个是右括
号。
例如,对于括号序列 (((),只需要添加两个括号就能让其合法,有以下几
种不同的添加结果:()()()、()(())、(())()、(()()) 和 ((()))。
【输入格式】
输入一行包含一个字符串 s,表示给定的括号序列,序列中只有左括号和
右括号。
【输出格式】
输出一个整数表示答案,答案可能很大,请输出答案除以 1000000007 (即
10 9 + 7) 的余数。

【样例输入】

((()

【样例输出】

5

【评测用例规模与约定】
对于 40% 的评测用例,|s| ≤ 200。
对于所有评测用例,1 ≤ |s| ≤ 5000。


  • 3
    点赞
  • 25
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值