1.判断输入日期是否合法
创建静态方法isLegalDate(String strDate)
package task05;
/**
* @功能:输出指定要求的回文日期
* @作者:罗燕
* @日期:2022-05-26
*/
public class PalindromicDate {
private 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;
}
}
2.创建主方法,测试输入日期是否合法
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+"]是非法日期");
}
}
运行程序,查看结果
3.判断是否是回文日期
判断是否是回文日期
private static boolean isPalifromicDate(String strDate){
for (int i = 0;i<4;i++){
采用反向思维
if (strDate.charAt(i)!=strDate.charAt(7-i))return false;
}
return true;
}
4.修改主方法,输出该日期后的第一个回文日期
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);
//输出该日期之后的第一个回文日期
String strDate1 = strDate;
Calendar calendar1 = calendar;
while (true) {
calendar1.add(Calendar.DAY_OF_MONTH, 1); // 往后推1天
strDate1 = sdf.format(calendar1.getTime());
if (isPalifromicDate(strDate1)) {
break; // 找到一个回文日期就跳出循环
}
}
System.out.println("该日期之后的第一个回文日期:" + strDate1);
}else {
System.out.println("["+strDate+"]是非法日期");
}