[蓝桥杯 2020 省 AB 2] 回文日期
题目描述
2020 年春节期间,有一个特殊的日期引起了大家的注意:2020 年 2 月 2 日。因为如果将这个日期按 yyyymmdd 的格式写成一个 888 位数是 20200202,恰好是一个回文数。我们称这样的日期是回文日期。
有人表示 20200202 是“千年一遇” 的特殊日子。对此小明很不认同,因为不到 2 年之后就是下一个回文日期:20211202 即 2021 年 12 月 2 日。
也有人表示 20200202 并不仅仅是一个回文日期,还是一个 ABABBABA 型的回文日期。对此小明也不认同,因为大约 100100100 年后就能遇到下一个 ABABBABA 型的回文日期:21211212 即 2121 年 12 月 12 日。算不上“千年一遇”,顶多算“千年两遇”。
给定一个 8 位数的日期,请你计算该日期之后下一个回文日期和下一个 ABABBABA 型的回文日期各是哪一天。
输入格式
输入包含一个八位整数 NNN,表示日期。
输出格式
输出两行,每行 111 个八位数。第一行表示下一个回文日期,第二行表示下
一个 ABABBABA 型的回文日期。
样例 #1
样例输入 #1
20200202
样例输出 #1
20211202
21211212
提示
对于所有评测用例,10000101≤N≤9220022910000101 \le N \le 9220022910000101≤N≤92200229,保证 NNN 是一个合法日期的 888 位数表示。
蓝桥杯 2020 第二轮省赛 A 组 G 题(B 组 G 题)。
思路
按日期枚举,判断是否符合条件,日期的处理很繁琐,需要仔细细心,debug 搞了半天,好在最后还是搞出来了
其实完成上有一个小的 BUG,我是直接从下一年开始遍历的,直接跳过了本年剩下的日期,如果出一个很刁钻的题设置了本年剩下的日期就跪了,好在并没有,100%通过。
import java.util.Scanner;
public class P8716 {
static int[] commonYear = new int[] {
31,28,31,30,31,30,31,31,30,31,30,31};
static int[] leapYear = new int[] {
31,

该博客主要介绍了蓝桥杯2020省赛AB2题目的具体内容——回文日期。博主讨论了回文日期的概念,并给出了一种解决方案,即通过枚举日期来判断是否为回文日期。文章还提醒在编程实现时需要注意处理日期的细节,以避免可能的错误。

1164

被折叠的 条评论
为什么被折叠?



