写在前面
这到没有什么技术含量的题目,卡了半天。原因是因为忘记考虑了日期的有效性。也就是月和天数是否有效。浪费了一个多小时…
题目描述
代码
public static void main(String[] args) {
Scanner sc = new Scanner(System.in);
String str = sc.next();
if (str.length() > 8)
return;
long nums = Long.valueOf(str);
nums++;
long tmp1 = nums;
while(true){
long res = isHuiWen(nums);
// 获取月份
long backFourPreTwo = (nums % 10000) / 100;
// 获取天数
long backFourBkTwo = (nums % 1000) % 100;
if (res != -1 && (backFourPreTwo > 0 && backFourPreTwo <= 12) && (backFourBkTwo > 0 && backFourBkTwo <= 31)){
System.out.println(nums);
break;
}
nums++;
}
while(true){
long res = isHuiWen(tmp1);
// 获取前两位
long preTwo = tmp1 / 1000000;
// 获取3、4位
long bakTwo = (tmp1 / 10000) % 100;
// 获取月份
long backFourPreTwo = (tmp1 % 10000) / 100;
// 获取天数
long backFourBkTwo = (tmp1 % 1000) % 100;
if (res != -1 && (preTwo == bakTwo) && (backFourPreTwo > 0 && backFourPreTwo <= 12) && (backFourBkTwo > 0 && backFourBkTwo <= 31)){
System.out.println(tmp1);
break;
}
tmp1++;
}
}
// 判断是否是回文数
public static long isHuiWen(long nums){
String str = String.valueOf(nums);
int i = 0;
for (i = str.length()-1; i >= str.length() / 2; i--){
if (str.charAt(i) != str.charAt(str.length()-1-i)){
break;
}
}
if (i == str.length() /2 - 1){
return nums;
}
return -1;
}