一、[蓝桥杯2022初赛] 九进制转十进制
九进制正整数(2022) 转换成十进制等于多少?
这是一道结果填空的题,你只需要算出结果后提交即可。
本题的结果为一个整数,在提交答案时只输出这个整数,输出多余的内容将无法得分。
本体为基本的进制转换问题个位乘以 (9的0次方) 加上 十位乘以 (9的一次方) 加上 百位乘以 (9的二次方)。也即2*1+2*9+0*9*9+2*9*9*9;
代码如下:
#include<iostream>
using namespace std;
int main()
{
cout << 2 + 2 * 9 + 2 * 9 * 9 * 9 << endl;
}
二、 [蓝桥杯2022初赛] 顺子日期
小明特别喜欢顺子。顺子指的就是连续的三个数字:123、456 等。
顺子日期指的就是在日期的 yyyymmdd 表示法中,存在任意连续的三位数是一个顺子的日期。
例如20220123 就是一个顺子日期,因为它出现了一个顺子:123;
本题顺子的定义:i j k 是一个顺子,满足 i+1=j、j+1=k、i≥0。
而20221023 则不是一个顺子日期,它一个顺子也没有。
小明想知道在整个2022年份中,一共有多少个顺子日期。
这是一道结果填空的题,你只需要算出结果后提交即可。
本题的结果为一个整数,在提交答案时只输出这个整数,输出多余的内容将无法得分。
根据日期进行遍历即可。
代码如下:
#include<iostream>
using namespace std;
int month[13] = { 0,31,28,31,30,31,30,31,31,30,31,30,31 };
int main()
{
int get[4];
int count = 0;
for (int i = 20220101; i <= 20221231; i++)
{
get[0] = i % 10;
get[1] = (i/10) % 10;
get[2] = (i / 100) % 10;
get[3] = (i / 1000) % 10;
if (get[3] * 10 + get[2] <= 12 && get[3] * 10 + get[2] >= 1)
{
if (get[1] * 10 + get[0] >= 1 && get[1] * 10 + get[0] <= month[get[3] * 10 + get[2]])
{
if (get[3] + 1 == get[2] && get[2] + 1 == get[1] || get[2] + 1 == get[1] && get[1] + 1 == get[0])
{
count++;
}
}
}
}
cout << count << endl;
}
三、 [蓝桥杯2022初赛] 刷题统计
小明决定从下周一开始努力刷题准备蓝桥杯竞赛。
他计划周一至周五每天做 a 道题目,周六和周日每天做 b 道题目。
请你帮小明计算,按照计划他将在第几天实现做题数大于等于 n 题?
通过简要模拟即可得到:
#include<iostream>
using namespace std;
int main()
{
long long a, b, n;
long long sum = 0; int i;
scanf("%lld%lld%lld", &a, &b, &n);
long long week = n / (a * 5 + b * 2);
long long orther=n-week* (a * 5 + b * 2);
sum = week * 7;
for (i = 1; i <= 7; i++)
{
if(orther >0)
{