2017第八届蓝桥杯C/C++ B组省赛-日期问题

标题:日期问题

小明正在整理一批历史文献。这些历史文献中出现了很多日期。小明知道这些日期都在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 } 
 
时间: 2024-10-27 07:32:49

2017第八届蓝桥杯C/C++ B组省赛-日期问题的相关文章

2017第八届蓝桥杯C/C++ B组省赛个人代码

第一题 标题: 购物单 小明刚刚找到工作,老板人很好,只是老板夫人很爱购物.老板忙的时候经常让小明帮忙到商场代为购物.小明很厌烦,但又不好推辞. 这不,XX大促销又来了!老板夫人开出了长长的购物单,都是有打折优惠的. 小明也有个怪癖,不到万不得已,从不刷卡,直接现金搞定. 现在小明很心烦,请你帮他计算一下,需要从取款机上取多少现金,才能搞定这次购物. 取款机只能提供100元面额的纸币.小明想尽可能少取些现金,够用就行了. 你的任务是计算出,小明最少需要取多少现金. 以下是让人头疼的购物单,为了保

2017第八届蓝桥杯C/C++ B组省赛-购物单

标题: 购物单 小明刚刚找到工作,老板人很好,只是老板夫人很爱购物.老板忙的时候经常让小明帮忙到商场代为购物.小明很厌烦,但又不好推辞. 这不,XX大促销又来了!老板夫人开出了长长的购物单,都是有打折优惠的. 小明也有个怪癖,不到万不得已,从不刷卡,直接现金搞定. 现在小明很心烦,请你帮他计算一下,需要从取款机上取多少现金,才能搞定这次购物. 取款机只能提供100元面额的纸币.小明想尽可能少取些现金,够用就行了. 你的任务是计算出,小明最少需要取多少现金. 以下是让人头疼的购物单,为了保护隐私,

2017第八届蓝桥杯C/C++ B组省赛-等差素数列

标题:等差素数列 2,3,5,7,11,13,....是素数序列. 类似:7,37,67,97,127,157 这样完全由素数组成的等差数列,叫等差素数数列. 上边的数列公差为30,长度为6. 2004年,格林与华人陶哲轩合作证明了:存在任意长度的素数等差数列. 这是数论领域一项惊人的成果! 有这一理论为基础,请你借助手中的计算机,满怀信心地搜索: 长度为10的等差素数列,其公差最小值是多少? 注意:需要提交的是一个整数,不要填写任何多余的内容和说明文字. 比赛的时候有点混乱,结果连暴力都没暴力

2017第八届蓝桥杯决赛(B组)4.发现环

描述 小明的实验室有N台电脑,编号1~N.原本这N台电脑之间有N-1条数据链接相连,恰好构成一个树形网络.在树形网络上,任意两台电脑之间有唯一的路径相连. 不过在最近一次维护网络时,管理员误操作使得某两台电脑之间增加了一条数据链接,于是网络中出现了环路.环路上的电脑由于两两之间不再是只有一条路径,使得这些电脑上的数据传输出现了BUG. 为了恢复正常传输.小明需要找到所有在环路上的电脑,你能帮助他吗? 输入 第一行包含一个整数N. 以下N行每行两个整数a和b,表示a和b之间有一条数据链接相连. 对

2016 第七届蓝桥杯 c/c++ B组省赛真题及解题报告

2016 第七届蓝桥杯 c/c++ B组省赛真题及解题报告 勘误1:第6题第4个 if最后一个条件粗心写错了,答案应为1580. 条件应为abs(a[3]-a[7])!=1,宝宝心理苦啊.!感谢zzh童鞋的提醒. 勘误2:第7题在推断连通的时候条件写错了,后两个if条件中是应该是<=12 落了一个等于号.正确答案应为116. 1.煤球数目 有一堆煤球.堆成三角棱锥形.详细: 第一层放1个, 第二层3个(排列成三角形), 第三层6个(排列成三角形), 第四层10个(排列成三角形). -. 假设一共

2015年第六届蓝桥杯C/C++B组省赛题目解析

一.奖券数目 有些人很迷信数字,比如带“4”的数字,认为和“死”谐音,就觉得不吉利.虽然这些说法纯属无稽之谈,但有时还要迎合大众的需求.某抽奖活动的奖券号码是5位数(10000-99999),要求其中不要出现带“4”的号码,主办单位请你计算一下,如果任何两张奖券不重号,最多可发出奖券多少张. 请提交该数字(一个整数),不要写任何多余的内容或说明性文字. 分析:直接枚举10000-99999之间的数字,如果带4,直接排除:不带4的,记录一次,直到枚举完后输出. #include <iostream

第八届蓝桥杯 JAVA(B组) 第二题“纸牌三角形”

class CardDelta{ int top=1; int left=3; int right=2; /* A 9 6 4 8 3 7 5 2 * */ public CardDelta() { } public void sort3Num() { for(int i = 1; i < 8; i++) { for(int j = i+1; j < 9; j++) { for(int k = j+1; k < 10; k++) { //System.out.println("

第七届蓝桥杯C\C++B组省赛题目——方格填数

第一部分:题目 方格填数 如下的10个格子   +--+--+--+   |  |  |  |+--+--+--+--+|  |  |  |  |+--+--+--+--+|  |  |  |+--+--+--+ (如果显示有问题,也可以参看下图) 填入0~9的数字.要求:连续的两个数字不能相邻.(左右.上下.对角都算相邻) 一共有多少种可能的填数方案? 请填写表示方案数目的整数.注意:你提交的应该是一个整数,不要填写任何多余的内容或说明性文字. 第二部分:思路 这个题目有点表述不明,不知道0~

第七届蓝桥杯C/C++B组省赛题目解析

题目1:煤球数目 有一堆煤球,堆成三角棱锥形.具体:第一层放1个,第二层3个(排列成三角形),第三层6个(排列成三角形),第四层10个(排列成三角形),....如果一共有100层,共有多少个煤球?请填表示煤球总数目的数字.注意:你提交的应该是一个整数,不要填写任何多余的内容或说明性文字. 解析: 第一层:1个. 第二层:2*3-3=3个. 第三层:3*3-3=6个. 第四层:4*3-3=10个. 代码如下: int s=0,a=0; for(int i=1;i<=100;i++){ a=a+i;