藍橋杯第八屆省賽 日期問題

2021-10-24 02:35:00 字數 1547 閱讀 6476

日期問題

小明正在整理一批歷史文獻。這些歷史文獻**現了很多日期。小明知道這些日期都在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

看到這個題目時開始感覺很多頭緒,而且需要很多單獨的小函式確定一些東西,如果全程傳遞這樣三個變數還是很麻煩的,所以用乙個結構體和乙個結構體陣列還是很方便的,因為給出的任意乙個輸入會有6種組合方式,一旦這個難點解決掉了,這個題就很簡單了。

**:

#include

#include

using

namespace std;

struct date

;void

print

(date&d)

bool

isyear

(int year)

bool

compare

(const date&d1,

const date&d2)

bool

checkdate

(date&d);if

(isyear

(d.year)

) months[2]

=29;else

months[2]

=28;if

(d.year<

1960

|| d.year>

2059

)return

false;if

(d.day<

1|| d.day>months[d.month]

)return

false

;return

true;}

bool

checkequals

(date date,

int i)

return

true;}

intmain()

,,,,

,,};

sort

(date,date+

6,compare)

;for

(int i=

0;i<

6;i++

)return0;

}

藍橋杯第八屆省賽

第4題 6x6的方格,沿著格仔的邊線剪開成兩部分。要求這兩部分的形狀完全相同。如圖 p1.png,p2.png,p3.png 就是可行的分割法。試計算 包括這3種分法在內,一共有多少種不同的分割方法。注意 旋轉對稱的屬於同一種分割法。請提交該整數,不要填寫任何多餘的內容或說明文字。圖的dfs 按照兩...

第八屆藍橋杯日期問題

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

第八屆藍橋杯 日期問題

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