蓝桥杯省赛习题练习(三)

文章包含四个编程问题的解决方案:1)九进制数转换为十进制;2)计算2022年中的顺子日期数量;3)统计达到特定做题数量所需的天数;4)探索积木填满2xN画布的不同方式。这些问题涉及数字转换、日期处理和逻辑判断等算法概念。
摘要由CSDN通过智能技术生成

题目来源:2022年第十三届省赛(B组)真题

1.九进制转十进制

问题描述:九进制正整数 (2022)9 转换成十进制等于多少?

#include<stdio.h>
#include<math.h>
int main()
{
	int nonarynum, decimalnum=0, i = 1,remainder;
	printf("Please enter a number:");
	scanf_s("%d", &nonarynum);
	while (nonarynum > 0)
	{
		remainder = nonarynum % 10;
		decimalnum = remainder * pow(9, i - 1) + decimalnum;
		nonarynum = nonarynum / 10;
		i++;
	}
	printf("九进制正整数2022转换成十进制等于%d\n", decimalnum);
	return 0;
}

运行结果

2. 顺子日期

问题描述:小明特别喜欢顺子。顺子指的就是连续的三个数字:123、456 等。
顺子日期指的就是在日期的 yyyymmdd 表示法中,存在任意连续的三位数是一个顺子的日期。
例如 20220123 就是一个顺子日期,因为它出现了一个顺子:123;而 20221023 则不是一个顺子日期,它一个顺子也没有。小明想知道在整个 2022年份中,一共有多少个顺子日期。

#include <iostream>
#include<string>
using namespace std;
int days[] = { 31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31 };
int ans = 0;
int main()
{
	for (int i = 1; i <= 12; i++)
	{
		for (int j = 1; j <= days[i]; j++)
		{
			//函数to_string用于把数字类型转换为string类型
			string s = "2022" + (to_string(i).size() == 2 ? to_string(i) : "0" + to_string(i)) + (to_string(j).size() == 2 ? to_string(j) : "0" + to_string(j));
			for (int i = 4; i < 6; i++) //年份中不可能出现顺子,因此从月份开始判断可减少循环次数
			{
				if (s[i] + 1 == s[i + 1] && s[i] + 2 == s[i + 2])
				{
					cout << s << endl;
					ans++;
					break; //一个日期中只要出现一个顺子即满足条件
				}
			}
		}
	}
	cout << "2022年份中,一共有" << ans << "个顺子日期" << endl;
	return 0;
}

运行结果

3. 刷题统计

问题描述:小明决定从下周一开始努力刷题准备蓝桥杯竞赛。
他计划周一至周五每天做 a 道题目,周六和周日每天做 b 道题目。
请你帮小明计算,按照计划他将在第几天实现做题数大于等于 n 题?

#include<stdio.h>
int main()
{
	int a, b, n, sum = 0, day = 1, count = 0;
	printf("Please input 3 numbers represent a、b、n:");
	scanf_s("%d %d %d", &a, &b, &n);
	while (sum < n)
	{

		if (day != 6 && day != 7) //周一至周五
		{
			sum = sum + a;
			day++;
			count++;
		}
		else //周六至周日
		{
			sum = sum + b;
			if (day % 7 == 0) day = 0; //星期天
			day++;
			count++;
		}
	}

	printf("按照计划他将在第%d天实现做题数大于等于%d题\n", count, n);
	return 0;
}

运行结果

4. 积木画

问题描述:小明最近迷上了积木画,有这么两种类型的积木,分别为 I 型(大小为 2个单位面积)和 L 型(大小为 3 个单位面积):
同时,小明有一块面积大小为 2 × N 的画布,画布由 2 × N 个 1 × 1 区域构成。
小明需要用以上两种积木将画布拼满,他想知道总共有多少种不同的方式?
积木可以任意旋转,且画布的方向固定。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值