2020第十一届蓝桥杯C++省赛B组题解 (10月第二场)

一年一度的暴力杯终于打完了

试题 A 门牌制作

【问题描述】
小蓝要为一条街的住户制作门牌号.
这条街一共有 2020 位住户,门牌号从 1 到 2020 编号.
小蓝制作门牌的方法是先制作 0 到 9 这几个数字字符,最后根据需要将字符粘贴到门牌上,例如门牌 1017 需要依次粘贴字符 1、 0、 1、 7,即需要 1 个字符 0, 2 个字符 1, 1 个字符 7.
请问要制作所有的 1 到 2020 号门牌,总共需要多少个字符 2?

【答案提交】
这是一道结果填空的题,你只需要算出结果后提交即可.本题的结果为一个整数,在提交答案时只填写这个整数,填写多余的内容将无法得分.

#include<iostream>
using namespace std;
typedef long long ll;

int main(void){
   
	int sum = 0;
	for(int i = 1;i<=2020;i++){
   
		int n = i;
		while(n){
   
			if(n%10==2){
   
				sum++;
			}
			n/=10;
		}
	}
	printf("%d\n",sum);
}

别告诉我你做错了


试题 B 既约分数

【问题描述】
如果一个分数的分子和分母的最大公约数是 1,这个分数称为既约分数.例如,3/4 ,5/2 ,1/8 ,7/1 都是既约分数.请问,有多少个既约分数,分子和分母都是 1 到 2020 之间的整数((包括 1 和 2020)?

#include<iostream>
using namespace std;
typedef long long ll;


//求最大公约数
int gcd(int a,int b){
   
	return b==0?a:gcd(b,a%b);
}

int main(void){
   
	ll sum = 0;
	for(int i = 1;i <= 2020;i++){
   
		for(int j = 1;j <= 2020;j++){
   
			//两数相等直接跳过(1/1的情况一会在加上)
			if(i == j){
   
				continue;
			}
			if(gcd(i,j)
  • 41
    点赞
  • 215
    收藏
    觉得还不错? 一键收藏
  • 4
    评论
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值