0
点赞
收藏
分享

微信扫一扫

【算法打卡】回文日期

扒皮狼 2022-03-11 阅读 51

写在前面

这到没有什么技术含量的题目,卡了半天。原因是因为忘记考虑了日期的有效性。也就是月和天数是否有效。浪费了一个多小时…

题目描述

代码

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;
    }
举报

相关推荐

0 条评论