小明正在整理一批歷史文獻。這些歷史文獻**現了很多日期。小明知道這些日期都在2023年1月1日至2023年12月31日。令小明頭疼的是,這些日期採用的格式非常不統一,有採用年/月/日的,有採用月/日/年的,還有採用日/月/年的。更加麻煩的是,年份也都省略了前兩位,使得文獻上的乙個日期,存在很多可能的日期與其對應。
比如02/03/04,可能是2023年03月04日、2023年02月03日或2023年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
不能通過工程設定而省略常用標頭檔案。
提交程式時,注意選擇所期望的語言型別和編譯器型別。
思路:
1,對於題目的輸入aa/bb/cc,有三種可能情況;
年/月/日 ————aa/bb/cc
月/日/年 ————cc/aa/bb
日/月/年————cc/bb/aa
2,分別對這三種情況的年月日的範圍,進行判定;
3,排序後,輸出結果。
#include #include #include #include using namespace std;
int monthnum[13][2] =,, , ,,,,
,,,,,};//日期打表
bool isleap(int y)
bool isyear(int x)
bool ismonth(int x)
bool isday(int year, int month, int day)
struct date
};vectorv;
void judge(int x, int y , int z)
}else}}
}bool cmp(const date &a, const date &b)else
}else if(a.m != b.m)else
}int main()elseelse}}
return 0;
}
參考**2:(使用set儲存)
#include #include #include #include #include using namespace std;
bool isleap(int year)
void i2s(int i, string &s)
string f(int a, int b, int c)
string _a, _b, _c;
i2s(a, _a);//數字轉為字串
i2s(b, _b);
i2s(c, _c);
if(_b.length() == 1) _b = "0" + _b;//對於只有1位的進行加0操作
if(_c.length() == 1) _c = "0" + _c;
return _a + "-" + _b + "-" + _c;//拼接成乙個日期
}int main()
return 0;
}
第八屆藍橋杯C B組 日期問題
小明正在整理一批歷史文獻。這些歷史文獻 現了很多日期。小明知道這些日期都在1960年1月1日至2059年12月31日。令小明頭疼的是,這些日期採用的格式非常不統一,有採用年 月 日的,有採用月 日 年的,還有採用日 月 年的。更加麻煩的是,年份也都省略了前兩位,使得文獻上的乙個日期,存在很多可能的日...
第八屆藍橋杯省賽C B組 日期問題(巧妙)
小明正在整理一批歷史文獻。這些歷史文獻 現了很多日期。小明知道這些日期都在1960年1月1日至2059年12月31日。令小明頭疼的是,這些日期採用的格式非常不統一,有採用年 月 日的,有採用月 日 年的,還有採用日 月 年的。更加麻煩的是,年份也都省略了前兩位,使得文獻上的乙個日期,存在很多可能的日...
第八屆藍橋杯日期問題
小明正在整理一批歷史文獻。這些歷史文獻中出現了很多日期。小明知道這些日期都在1960年1月1日至2059年12月31日。令小明頭疼的是,這些日期採用的格式非常不統一,有採用年 月 日的,有採用月 日 年的,還有採用日 月 年的。更加麻煩的是,年份也都省略了前兩位,使得文獻上的乙個日期,存在很多可能的...