测试输入日期是否合法
测试输入日期是否合法
运行程序,查看结果
判断是否是回文日期
/**
* 判断是否是回文日期
*
* @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,8));
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); // 往后推一天
strDate1 = sdf.format(calendar1.getTime());
if (isPalindromicDate(strDate1)){
break; // 找到一个回文日期就跳出循环
}
}
System.out.println("该日期之后的第一个回文日期:" + strDate1);
运行程序,查看结果
判断是否是ABABBABA型回文日期
/**
* 判断是否是ABABBABA型回文日期
*
*/
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;
}
}
把这一段代码加在最后面
运行程序,查看结果
完整代码
public class PanlindromicDate {
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,8));
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); // 往后推一天
strDate1 = sdf.format(calendar1.getTime());
if (isPalindromicDate(strDate1)){
break; // 找到一个回文日期就跳出循环
}
}
System.out.println("该日期之后的第一个回文日期:" + strDate1);
// 任务2、输出该日期之后的第一个ABABBABA型回文日期
String strDate2 = strDate;
Calendar calendar2 = calendar;
while (true) {
calendar2.add(Calendar.DAY_OF_MONTH, 1); // 往后推一天
strDate2 = sdf.format(calendar2.getTime());
if (isABABBABAPalindromicDate(strDate2)){
break; // 找到一个回文日期就跳出循环
}
}
System.out.println("该日期之后的第一个ABABBABA回文日期:" + strDate2);
}else{
System.out.println("[" + strDate + "]是非法日期");
}
}
/**
* 判断日期是否合法
*
* @param strDate
* @return turn-合法 ,false-非法
*/
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,8));
// 利用反向思维来处理
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
*/
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型回文日期
*
*/
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;
}
}
大家自己去试试吧!!!