藍橋杯 日期問題

2021-10-02 16:40:27 字數 1720 閱讀 6019

小明正在整理一批歷史文獻。這些歷史文獻**現了很多日期。

小明知道這些日期都在2023年1月1日至2023年12月31日。

令小明頭疼的是,這些日期採用的格式非常不統一,有採用年/月/日的,有採用月/日/年的,還有採用日/月/年的。

更加麻煩的是,年份也都省略了前兩位,使得文獻上的乙個日期,存在很多可能的日期與其對應。

比如02/03/04,可能是2023年03月04日、2023年02月03日或2023年03月02日。

給出乙個文獻上的日期,你能幫助小明判斷有哪些可能的日期對其對應嗎?

輸入格式

乙個日期,格式是」aa/bb/cc」。

即每個』/』隔開的部分由兩個 0-9 之間的數字(不一定相同)組成。

輸出格式

輸出若干個不相同的日期,每個日期一行,格式是」yyyy-mm-dd」。

多個日期按從早到晚排列。

資料範圍

0≤a,b,c≤9
輸入樣例:

02/03/04
輸出樣例:

2002-03-04

2004-02-03

2004-03-02

1、首先讀取到這個日期

2、把這個日期安排成題中給出的三種格式

3、挨個判斷一下這個是不是乙個合法的日期

因為要求他按照時間順序輸出,所以把他填充成乙個數字之後進行排序,同時判斷是否在題中給定的範圍內的時候也是用數字大小來比較;

**如下

#include

#include

#include

using

namespace std;

int days[13]

=;vector<

int> vdate;

int date1 =

19600101

, date2 =

20591231

;void

check

(int y,

int m,

int d)

vdate.

push_back

(date);}

voidp(

int date)

intmain()

這樣寫就是直接的判斷,幾乎沒有迴圈,時間複雜度肯定沒得問題;但是這**看起來長度有點過分

提供另一種想法:列舉

1、按數字對這個範圍內進行列舉

2、數字轉換成日期、判斷這個日期是否合法

3、判斷這個日期是否符合題目的輸入

**如下

#include

#include

#include

using

namespace std;

int days[13]

=;bool

check

(int year,

int month,

int day)

return

true;}

intmain()

}return0;

}

藍橋杯 日期問題

問題描述 小明正在整理一批歷史文獻。這些歷史文獻中出現了很多日期。小明知道這些日期都在1960年1月1日至2059年12月31日。令小明頭疼的是,這些日期採用的格式非常不統一,有採用年 月 日的,有採用月 日 年的,還有採用日 月 年的。更加麻煩的是,年份也都省略了前兩位,使得文獻上的乙個日期,存在...

藍橋杯 日期問題

問題描述 小明正在整理一批歷史文獻。這些歷史文獻 現了很多日期。小明知道這些日期都在1960年1月1日至2059年12月31日。令小明頭疼的是,這些日期採用的格式非常不統一,有採用年 月 日的,有採用月 日 年的,還有採用日 月 年的。更加麻煩的是,年份也都省略了前兩位,使得文獻上的乙個日期,存在很...

藍橋杯 日期問題

小明正在整理一批歷史文獻。這些歷史文獻 現了很多日期。小明知道這些日期都在1960年1月1日至2059年12月31日。令小明頭疼的是,這些日期採用的格式非常不統一,有採用年 月 日的,有採用月 日 年的,還有採用日 月 年的。更加麻煩的是,年份也都省略了前兩位,使得文獻上的乙個日期,存在很多可能的日...