题目
2020 年春节期间,有一个特殊的日期引起了大家的注意:2020 年 2 月 2 日。因为如果将这个日期按 “yyyymmdd” 的格式写成一个 8 位数是 20200202,恰好是一个回文数。我们称这样的日期是回文日期。
有人表示 20200202 是 “千年一遇” 的特殊日子。对此小明很不认同,因为不到 2 年之后就是下一个回文日期:20211202 即 2021 年 12 月 2 日。
也有人表示 20200202 并不仅仅是一个回文日期,还是一个 ABABBABA 型的回文日期。对此小明也不认同,因为大约 100 年后就能遇到下一个 ABABBABA 型的回文日期:21211212 即 2121 年 12 月 12 日。算不上 “千年一遇”,顶多算 “千年两遇”。
给定一个 8 位数的日期,请你计算该日期之后下一个回文日期和下一个 ABABBABA 型的回文日期各是哪一天。
解题
思路
利用LocalDate完成,不断让时间加1,同时用将其转成字符串后放入StringBuilder中并反转,比较反转前后的值是否一致
题目要求判断两个时间,定义while循环,当且仅当两个判断都完成后结束循环,输出结果
代码
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45
| import java.time.LocalDate; import java.time.format.DateTimeFormatter; import java.util.Scanner; public class Main { public static void main(String[] args) { Scanner sc = new Scanner(System.in); String time = sc.next(); DateTimeFormatter dtf1=DateTimeFormatter.ofPattern("yyyyMMdd"); LocalDate l = LocalDate.parse(time,dtf1); String lStr,sbStr = null; boolean fa1 = false,fa2 = false; while (true){ l = l.plusDays(1); lStr = l.format(dtf1); if (!fa1) { sbStr = new StringBuilder(lStr).reverse().toString(); if (lStr.equals(sbStr)) fa1 = true; } if (!fa2) { String a1 = lStr.substring(0, 2); String a2 = lStr.substring(2, 4); if (a1.equals(a2)) { String a12 = lStr.substring(0, 4); String a34 = lStr.substring(4, 8); if (new StringBuilder(a12).reverse().toString().equals(a34)) fa2 = true; } } if (fa1&&fa2) break; } System.out.println(sbStr + "\n" + l.format(dtf1)); } }
|