解题思路:

既要判断是否为合理日期(1960年1月1日至2059年12月31日,闰年2月有29天,平年2月28,大月31,小月30等),又要将日期从小到大排序,尤其是从小到大排 序,情况很复杂,很难考虑全面,所以可以考虑换个角度解题。既然日期在1960年1月1日至2059年12月31日范围内,可以从1960年1月1日(19600101)遍历到2059年12月31日(20591231),分别取出前四位作为年,中间两位作为月,最后两位作为日,判断这个日期是否是合法日期。如果是合法日期,再与输入的AA、BB、CC分别按照年月日、月日年、日月年三种方式比较,如果相等,则输出。

注意事项:

学会转换思路很重要,一种方法行不通,就想想这个题目是不是有什么规律可以帮助我们解题,想想换个思路会不会更简单。

参考代码:

import java.text.ParseException;
/*
年/月/日、月/日/年、日/月/年
日期都在1960年1月1日至1999年12月31日
	    2000年1月1日到2059年12月31日
年份省略了前两位
 */
import java.text.SimpleDateFormat;
import java.util.Date;
import java.util.*;
public class Main{
	public static int month[] = {0,31,28,31,30,31,30,31,31,30,31,30,31};
	
	public static boolean Check(int y,int m,int d) {//检查是否是合法日期
		if(y<1960 || y>2059) return false;
		if(m<1 || m>12) return false;
//		1.能被4整除而不能被100整除。2.能被100整除也能被400整除。
		int flag=0;
		if(y%4==0&&y%100!=0 || y%400==0&&y%100==0) flag=1; //判断闰年
		if(d<1 || d>month[m]+flag) return false;
		return true;
	}
	public static void main(String[] args) {
		Scanner sc = new Scanner(System.in);
		String str = sc.next();
		String s[] = str.split("/");
		int A = Integer.parseInt(s[0]);
		int B = Integer.parseInt(s[1]);
		int C = Integer.parseInt(s[2]);
		for(int i=19600101;i<=20591231;i++) {
			int y=i/10000;
			int m=i%10000/100;
			int d=i%100;
			if(Check(y,m,d)) {
				if(y%100==A && m==B && d==C || //年月日
				   m==A && d==B && y%100==C || //月日年
				   d==A && m==B && y%100==C) { //日月年
					String Year = String.valueOf(y);
					String Month = String.format("%2d",m).replace(" ","0"); //空位补0
					String Day = String.format("%2d",d).replace(" ","0");
					System.out.println(Year+"-"+Month+"-"+Day);
				}
					
			}
			
		}
	}

}


点赞(0)
 

0.0分

2 人评分

C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:

一点编程也不会写的:零基础C语言学练课程

解决困扰你多年的C语言疑难杂症特性的C语言进阶课程

从零到写出一个爬虫的Python编程课程

只会语法写不出代码?手把手带你写100个编程真题的编程百练课程

信息学奥赛或C++选手的 必学C++课程

蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程

手把手讲解近五年真题的蓝桥杯辅导课程

评论列表 共有 1 条评论

cold 2年前 回复TA
输入00/01/32时结果是2000-01-32啊