Java学习:蓝桥杯,回文日期判断

一、判断日期是否为合法日期

创建 判断日期是否合法类
在这里插入图片描述

  • 代码
package net.zwh.lanqiao;

import java.util.Scanner;

public class PalindromicDate {
    
    /**
     * 判断日期是否合法
     * @param strDate
     * @return true-合法,false-非法
     */
    public static boolean isLegalDate(String strDate) {
        int year, month, day;
        year = Integer.parseInt(strDate.substring(0, 4));
        month = Integer.parseInt(strDate.substring(4,6));
        day = Integer.parseInt(strDate.substring(6));

        // 利用反向思维来处理
        if (year < 1000 || year > 8999) return false;
        if (month < 1 || month > 12) return false;

        if (month == 1 || month == 3 || month == 5 || month == 7 || month == 8 || month == 10 || month == 12) {
            if (day < 1 || day > 31) return false;
        } else if (month == 2){
            if (year % 4 == 0 && year %100 != 0 || year % 400 == 0 ) { // 闰年判断
                if(day < 1 || day > 29) return false;
            }else {
                if(day < 1 || day > 28) return false;
            }
        } else {
            if (day < 1 || day > 30) return false;
        }
        return true;
    }
}

创建主方法,测试输入日期是否合法

 public static void main(String[] args) {                          
     String strDate;                                               
     int year, month, day;                                         
     Scanner sc = new Scanner(System.in);                          
                                                                   
     System.out.print("输入8位数构成的日期:");                              
     strDate = sc.next();                                          
     if (isLegalDate(strDate)) {                                   
         System.out.println("[" + strDate + "], 是合法日期~");          
     } else {                                                      
         System.out.println("[" + strDate + "], 是非法日期~");          
     }                                                                                                                       
 }                                                                 
  • 运行代码,查看结果
    在这里插入图片描述
  • 月份不对
    在这里插入图片描述
  • 年月日都对,但长度不对
    在这里插入图片描述

二、判断是否是回文日期

  • 定义静态方法isPalindromicDate()
    在这里插入图片描述
/**
     * 判断是否是回文日期
     * @param strDate
     * @return true-回文日期, false-非回文日期
     */
    private static boolean isPalindromicDate(String strDate) {
        for (int i = 0; i < 4; i++) {
            // 采用反向思维
            if (strDate.charAt(i) != strDate.charAt(7-i)) return false;
        }
        return true;
    }

三、修改主方法,输出该日期的第一个回文日期

在这里插入图片描述

  • 输出代码
    在这里插入图片描述
 // 将用户输入的合法日期作为日期循环的起点
            year = Integer.parseInt(strDate.substring(0, 4));
            month = Integer.parseInt(strDate.substring(4,6));
            day = Integer.parseInt(strDate.substring(6));
            Calendar calendar = Calendar.getInstance();
            calendar.set(year, month - 1, day);
            // 任务1:输出该日期之后的第一个回文日期
            String strDate1 =strDate;
            Calendar calendar1 = calendar;
            while (true) {
                calendar1.add(Calendar.DAY_OF_MONTH, 1); // 往后推1天
                strDate1 = sdf.format(calendar1.getTime());
                if(isPalindromicDate(strDate1)) {
                    break; // 找到1个回文日期就跳出循环
                }
            }
            System.out.println("【" + strDate + "】之后的第一个回文日期:" + "【" + strDate1 + "】" );

四、判断是否是ABABBABA型回文日期

在这里插入图片描述

  • 代码
/**
     * 判断是否是ABABBABA型回文日期
     *
     * @param strDate
     * @return
     */
    private static boolean isABABBABAPalindromicDate(String strDate) {
        if (isPalindromicDate(strDate)) {
            if (strDate.charAt(0) == strDate.charAt(2) && strDate.charAt(1) == strDate.charAt(3)) return true;
        }
        return false;
    }

五、修改主方法,输出该日期的第一个ABABBABA型回文日期

在这里插入图片描述

  • 代码
// 任务2:输出该日期之后的第一个ABABBABA回文日期
            String strDate2 =strDate;
            Calendar calendar2 = calendar;
            while (true) {
                calendar2.add(Calendar.DAY_OF_MONTH, 1); // 往后推1天
                strDate2 = sdf.format(calendar2.getTime());
                if(isABABBABAPalindromicDate(strDate2)) {
                    break; // 找到1个回文日期就跳出循环
                }
            }

            System.out.println("该日期之后的第一个ABABBABA回文日期:【" + strDate2 + "】" );
        } else {
            System.out.println("[" + strDate + "], 是非法日期~");
        }

  • 运行代码,查看结果
    在这里插入图片描述
    在这里插入图片描述

六、完整代码

package net.zwh.lanqiao;

import java.text.SimpleDateFormat;
import java.util.Calendar;
import java.util.Scanner;

public class PalindromicDate {
    public static void main(String[] args) {
        String strDate;
        int year, month, day;
        Scanner sc = new Scanner(System.in);
        SimpleDateFormat sdf = new SimpleDateFormat("yyyyMMdd");

        System.out.print("输入8位数构成的日期:");
        strDate = sc.next();

        if (isLegalDate(strDate)) {
            System.out.println("[" + strDate + "], 是合法日期~");
            // 将用户输入的合法日期作为日期循环的起点
            year = Integer.parseInt(strDate.substring(0, 4));
            month = Integer.parseInt(strDate.substring(4,6));
            day = Integer.parseInt(strDate.substring(6));
            Calendar calendar = Calendar.getInstance();
            calendar.set(year, month - 1, day);
            // 任务1:输出该日期之后的第一个回文日期
            String strDate1 =strDate;
            Calendar calendar1 = calendar;
            while (true) {
                calendar1.add(Calendar.DAY_OF_MONTH, 1); // 往后推1天
                strDate1 = sdf.format(calendar1.getTime());
                if(isPalindromicDate(strDate1)) {
                    break; // 找到1个回文日期就跳出循环
                }
            }

            System.out.println("该日期之后的第一个回文日期:【" + strDate1 + "】" );


            // 任务2:输出该日期之后的第一个ABABBABA回文日期
            String strDate2 =strDate;
            Calendar calendar2 = calendar;
            while (true) {
                calendar2.add(Calendar.DAY_OF_MONTH, 1); // 往后推1天
                strDate2 = sdf.format(calendar2.getTime());
                if(isABABBABAPalindromicDate(strDate2)) {
                    break; // 找到1个回文日期就跳出循环
                }
            }

            System.out.println("该日期之后的第一个ABABBABA回文日期:【" + strDate2 + "】" );
        } else {
            System.out.println("[" + strDate + "], 是非法日期~");
        }

    }
    /**
     * 判断日期是否合法
     * @param strDate
     * @return true-合法,false-非法
     */
    public static boolean isLegalDate(String strDate) {
        int year, month, day;
        year = Integer.parseInt(strDate.substring(0, 4));
        month = Integer.parseInt(strDate.substring(4,6));
        day = Integer.parseInt(strDate.substring(6));

        // 利用反向思维来处理
        if (year < 1000 || year > 8999) return false;
        if (month < 1 || month > 12) return false;

        if (month == 1 || month == 3 || month == 5 || month == 7 || month == 8 || month == 10 || month == 12) {
            if (day < 1 || day > 31) return false;
        } else if (month == 2){
            if (year % 4 == 0 && year %100 != 0 || year % 400 == 0 ) { // 闰年判断
                if(day < 1 || day > 29) return false;
            }else {
                if(day < 1 || day > 28) return false;
            }
        } else {
            if (day < 1 || day > 30) return false;
        }
        return true;
    }

    /**
     * 判断是否是回文日期
     * @param strDate
     * @return true-回文日期, false-非回文日期
     */
    private static boolean isPalindromicDate(String strDate) {
        for (int i = 0; i < 4; i++) {
            // 采用反向思维
            if (strDate.charAt(i) != strDate.charAt(7-i)) return false;
        }
        return true;
    }

    /**
     * 判断是否是ABABBABA型回文日期
     *
     * @param strDate
     * @return
     */
    private static boolean isABABBABAPalindromicDate(String strDate) {
        if (isPalindromicDate(strDate)) {
            if (strDate.charAt(0) == strDate.charAt(2) && strDate.charAt(1) == strDate.charAt(3)) return true;
        }
        return false;
    }
}

  • 2
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值