原题链接:蓝桥杯2017年第八届真题-日期问题
解题思路:
既要判断是否为合理日期(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分
2 人评分
C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:
一点编程也不会写的:零基础C语言学练课程
解决困扰你多年的C语言疑难杂症特性的C语言进阶课程
从零到写出一个爬虫的Python编程课程
只会语法写不出代码?手把手带你写100个编程真题的编程百练课程
信息学奥赛或C++选手的 必学C++课程
蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程
手把手讲解近五年真题的蓝桥杯辅导课程
发表评论 取消回复