蓝桥杯 试题 G: 回文日期

这是一个C++程序,用于判断给定日期的下一个回文日期和AB型日期。程序首先定义了判断回文和AB型日期的函数,然后通过闰年判断计算下一个日期,直至找到符合条件的日期。最后输出这两个特殊日期。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

#include<iostream>
#include<algorithm>
#include<string>
using namespace std;

//判断是否是回文日期
bool huiwen(string str)
{
	string str1 = str;
	reverse(str1.begin(), str1.end());
	if (str1 != str) return false;
	return true;
}
//判断是否是AB型日期
bool ab(string str)
{
	if (str[0] == str[2] && str[1] == str[3] && str[0] != str[1])
		return true;
	return false;
}
//闰年判断
bool isleap(int y)
{
	if ((y % 4 == 0 && y % 100 != 0) || y % 400 == 0) return true;
	return false;
}
int main()
{
	int n;
	cin >> n;
	int y, m, d;
	y = n / 10000;
	m = n % 10000 / 100;
	d = n % 100;
	int ans1 = 0, ans2 = 0;
	while (1)
	{
		d++;
		if (d == 32 && m == 12)
		{
			m = 1;
			d = 1;
			y++;
		}
		if (d == 32 && (m == 1 || m == 3 || m == 5 || m == 7 || m == 8 || m == 10))
			d = 1, m++;
		if (d == 31 && (m == 4 || m == 6 || m == 9 || m == 11))
			d = 1, m++;
		if (d == 30 && m == 2 && isleap(y))
			d = 1, m++;
		if (d == 29 && m == 2 && !isleap(y))
			d = 1, m++;

		int num = y * 10000 + m * 100 + d;
		string str = to_string(num);
		if (huiwen(str))
		{
			if (!ans1) ans1 = num;
			if (!ans2 && ab(str))
			{
				ans2 = num;
				break;
			}
		}
	}

	cout << ans1 << endl;
	cout << ans2 << endl;

	system("pause");
	return 0;
}

 

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值