小明正在整理一批历史文献。这些历史文献中出现了很多日期。小明知道这些日期都在 1960 年 1 月 1 日至 2059 年 12 月 31 日。令小明头疼的是,这些日期采用的格式非常不统一,有采用年/月/日
的,有采用月/日/年
的,还有采用日/月/年
的。更加麻烦的是,年份也都省略了前两位,使得文献上的一个日期,存在很多可能的日期与其对应。
比如 02/03/04
,可能是 2002 年 03 月 04 日、2004 年 02 月 03 日或 2004 年 03 月 02 日。
给出一个文献上的日期,你能帮助小明判断有哪些可能的日期对其对应吗?
输入 #
02/03/04
输出 #
2002-03-04
2004-02-03
2004-03-02
#include <iostream>
using namespace std;
int days[13]={0,31,30,31,30,31,30,31,31,30,31,30,31};
bool check_valid(int year,int month,int day){ //重点
if(month==0 ||month>12){ //判断
return false;
if(day==0 ||month!=2 &&day>days[month])
return false;
if(month==2){ //如果是二月特殊情况
int leap=year%100!=0 &&year%4==0 ||year%400==0;
if(day>days[2]+leap)
return false;
}
}
return true;
}
int main(int argc, char** argv) {
int a,b,c;
scanf("%a/%b/%c",&a,&b,&c);
for(int i=19600101;i<=20251231;i++){
int year=i/1000, month=i/100%100, day=i%100; //分别取年月日
if(check_valid(year,month,day)){ //自定义方法,检查是否满足条件。
if(year%100==a && month==b &&day==c ||month==a &&day==b &&year%100==c ||day==a &&month==b &&year%100==c){ //重点
printf("%d-%02d-%02d\n",year,month,day);
}
}
}
return 0;
}