标签:clu amp continue bsp 头文件 输入 函数 环境 nbsp
标题:日期问题
小明正在整理一批历史文献。这些历史文献中出现了很多日期。小明知道这些日期都在1960年1月1日至2059年12月31日。令小明头疼的是,这些日期采用的格式非常不统一,有采用年/月/日的,有采用月/日/年的,还有采用日/月/年的。更加麻烦的是,年份也都省略了前两位,使得文献上的一个日期,存在很多可能的日期与其对应。
比如02/03/04,可能是2002年03月04日、2004年02月03日或2004年03月02日。
给出一个文献上的日期,你能帮助小明判断有哪些可能的日期对其对应吗?
输入
----
一个日期,格式是"AA/BB/CC"。 (0 <= A, B, C <= 9)
输出
----
输出若干个不相同的日期,每个日期一行,格式是"yyyy-MM-dd"。多个日期按从早到晚排列。
样例输入
----
02/03/04
样例输出
----
2002-03-04
2004-02-03
2004-03-02
资源约定:
峰值内存消耗(含虚拟机) < 256M
CPU消耗 < 1000ms
请严格按要求输出,不要画蛇添足地打印类似:“请您输入...” 的多余内容。
注意:
main函数需要返回0;
只使用ANSI C/ANSI C++ 标准;
不要调用依赖于编译环境或操作系统的特殊函数。
所有依赖的函数必须明确地在源文件中 #include <xxx>
不能通过工程设置而省略常用头文件。
提交程序时,注意选择所期望的语言类型和编译器类型。
当时唯一能写出来的大题,写出来的时候特别兴奋,可是当我比赛最后几秒无意识的瞎测数据的时候发现,,,我只对年份排序了,,忘了排序月了,,希望样例多爱我几分QAQ
1 #include<stdio.h> 2 #include<algorithm> 3 using namespace std; 4 struct A{ 5 int x,y,z; 6 }AC[3]; 7 bool cmp(A a,A b) 8 { 9 if(a.x==b.x) 10 { 11 if(a.y==b.y) 12 { 13 return a.z<b.z; 14 } 15 return a.y<b.y; 16 } 17 return a.x<b.x; 18 } 19 int run(int a) 20 { 21 if((a%400==0)||(a%100!=0)&&(a%4==0)) 22 return 1; 23 return 0; 24 } 25 int main() 26 { 27 int a,b,c,i,aa,cc; 28 while(scanf("%d/%d/%d",&a,&b,&c)!=EOF) 29 { 30 if(a>=60&&a<=99) 31 aa=a+1900; 32 else 33 aa=a+2000; 34 if(c>=60&&c<=99) 35 cc=c+1900; 36 else 37 cc=c+2000; 38 39 AC[0].x=aa;AC[0].y=b;AC[0].z=c; 40 AC[1].x=cc;AC[1].y=a;AC[1].z=b; 41 AC[2].x=cc;AC[2].y=b;AC[2].z=a; 42 sort(AC,AC+3,cmp); 43 for(i=0;i<3;i++) 44 { 45 if(i>0) 46 { 47 if(AC[i].x==AC[i-1].x&&AC[i].y==AC[i-1].y&&AC[i].z==AC[i-1].z) 48 continue; 49 } 50 if(AC[i].x>=1960&&AC[i].x<=2059) 51 { 52 if(AC[i].y>=1&&AC[i].y<=12) 53 { 54 if(AC[i].y==2) 55 { 56 if(run(AC[i].x)) 57 { 58 if(AC[i].z>=1&&AC[i].z<=29) 59 { 60 printf("%d-%02d-%02d\n",AC[i].x,AC[i].y,AC[i].z); 61 } 62 } 63 else 64 { 65 if(AC[i].z>=1&&AC[i].z<=28) 66 { 67 printf("%d-%02d-%02d\n",AC[i].x,AC[i].y,AC[i].z); 68 } 69 } 70 } 71 else if(AC[i].y==4||AC[i].y==6||AC[i].y==9||AC[i].y==11) 72 { 73 if(AC[i].z>=1&&AC[i].z<=30) 74 { 75 printf("%d-%02d-%02d\n",AC[i].x,AC[i].y,AC[i].z); 76 } 77 } 78 else 79 { 80 if(AC[i].z>=1&&AC[i].z<=31) 81 { 82 printf("%d-%02d-%02d\n",AC[i].x,AC[i].y,AC[i].z); 83 } 84 } 85 } 86 } 87 } 88 } 89 return 0; 90 }
标签:clu amp continue bsp 头文件 输入 函数 环境 nbsp
原文地址:http://www.cnblogs.com/ljmzzyk/p/6918643.html