解题思路:

注意事项:

参考代码:

#include<iostream>
#include<cstdio>
#include<algorithm>
using namespace std;
struct RQ{
	int yyyy;
	int MM;
	int dd;
};
int month[13]={0,31,28,31,30,31,30,31,31,30,31,30,31};
inline int isRun(int y,int m){
	if(y%4==0 && y%100!=0 || y%400==0)
		if(m==2)
			return month[m]+1;
	return month[m];
}
int a[4];
struct RQ rq[1000];
bool cmp(struct RQ rq1,struct RQ rq2){
	if(rq1.yyyy==rq2.yyyy){
		if(rq1.MM==rq2.MM)
			return rq1.dd<rq2.dd;
		return rq1.MM<rq2.MM;
	}
	return rq1.yyyy<rq2.yyyy;
}
int main(){
	int num=0;
	ios::sync_with_stdio(false);
	cin.tie(0);
	cout.tie(0);
	scanf("%d/%d/%d",&a[1],&a[2],&a[3]);//a[2]一定不能是年份,月份一定是a[1]或者a[2] 
	int y1=a[1],y2=a[2],y3=a[3];
	//a[1]肯定<=12  a[2]肯定<=31  a[3]可能性很多 
	sort(a+1,a+3+1);
	//年月日
	//a[1]为年份
	rq[num].yyyy=2000+a[1];
	if(a[3]<=12){  //a[2],a[3]都可能是月份 
		rq[num].MM=a[2],rq[num].dd=a[3];
		rq[++num].yyyy=2000+a[1],rq[num].MM=a[3],rq[num].dd=a[2];
		num++;
	}
	else if(a[3]>12){
		if(a[3]<=isRun(2000+a[1],a[2]))
			rq[num].MM=a[2],rq[num].dd=a[3],num++;
	}
	//a[2]为年份
	rq[num].yyyy=2000+a[2];
	if(a[3]<=12){  //a[3],a[1]都可能是月份 
		rq[num].MM=a[1],rq[num].dd=a[3];
		rq[++num].yyyy=2000+a[2],rq[num].MM=a[3],rq[num].dd=a[1];
		num++;
	}
	else if(a[3]>12){
		if(a[3]<=isRun(2000+a[2],a[1]))
			rq[num].MM=a[1],rq[num].dd=a[3],num++;
	}
	//a[3]为年份
	if(a[3]>=60){
	 	rq[num].yyyy=1900+a[3];
	 	if(a[2]>12){ 
	 		if(a[2]<=isRun(1900+a[3],a[1]))
	 			rq[num].MM=a[1],rq[num].dd=a[2];
	 		//num++;
		}
		else if(a[2]<=12){ //a[2],a[1]都可能是月份 
			rq[num].MM=a[1],rq[num].dd=a[2];
			rq[++num].yyyy=1900+a[3],rq[num].MM=a[2],rq[num].dd=a[1];
			//num++;
		}
	}
	else if(a[3]<60){
		rq[num].yyyy=2000+a[3];
	 	if(a[2]>12){ 
	 		if(a[2]<=isRun(2000+a[3],a[1]))
	 			rq[num].MM=a[1],rq[num].dd=a[2];
	 		//num++;
		}
		else if(a[2]<=12){ //a[2],a[1]都可能是月份 
			rq[num].MM=a[1],rq[num].dd=a[2];
			rq[++num].yyyy=2000+a[3],rq[num].MM=a[2],rq[num].dd=a[1];
			//num++;
		}
	}
	sort(rq,rq+num+1,cmp);
	//便于理解,可以看到重复的日期 
	/*
	for(int i=0;i<=num;i++){
		cout << rq[i].yyyy << '-' << rq[i].MM << '-' << rq[i].dd << endl;
	}
	*/
	for(int i=0;i<=num;i++){
		if(rq[i].MM!=0 && rq[i].dd!=0) //月份和日期不能为0 
			if(rq[i].yyyy%100!=y2 || y1==y2 || y3==y2){ //按道理第二个不能为年份,但是如果其他两个存在与之相等,则可以 
				if(rq[i].MM==y1 || rq[i].MM==y2){
					if(rq[i].yyyy==rq[i-1].yyyy && rq[i].MM==rq[i-1].MM && rq[i].dd==rq[i-1].dd);//去重 
					else{
						cout << rq[i].yyyy << '-';
						if(rq[i].MM<10)
							cout << '0' << rq[i].MM << '-';
						else
							cout << rq[i].MM << '-';
						if(rq[i].dd<10)
							cout << '0' << rq[i].dd << endl;
						else
							cout << rq[i].dd << endl;
					}
				}
			}
	}
	return 0;
}


点赞(0)
 

0.0分

2 人评分

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

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

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

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

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

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

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

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

评论列表 共有 0 条评论

暂无评论