1014 福爾摩斯的約會 20分

2021-10-17 11:03:42 字數 2017 閱讀 5298

###1014 福爾摩斯的約會 (20分)

###題目

大偵探福爾摩斯接到一張奇怪的字條:我們約會吧! 3485djdkxh4hhge 2984akdfkkkkggedsb s&hgsfdk d&hyscvnm。大偵探很快就明白了,字條上奇怪的亂碼實際上就是約會的時間星期四 14:04,因為前面兩字串中第 1 對相同的大寫英文本母(大小寫有區分)是第 4 個字母 d,代表星期四;第 2 對相同的字元是 e ,那是第 5 個英文本母,代表一天裡的第 14 個鐘頭(於是一天的 0 點到 23 點由數字 0 到 9、以及大寫字母 a 到 n 表示);後面兩字串第 1 對相同的英文本母 s 出現在第 4 個位置(從 0 開始計數)上,代表第 4 分鐘。現給定兩對字串,請幫助福爾摩斯解碼得到約會的時間。

輸入格式:

輸入在 4 行中分別給出 4 個非空、不包含空格、且長度不超過 60 的字串。

輸出格式:

在一行中輸出約會的時間,格式為 day hh:mm,其中 day 是某星期的 3 字元縮寫,即 mon 表示星期一,tue 表示星期二,wed 表示星期三,thu 表示星期四,fri 表示星期五,sat 表示星期六,sun 表示星期日。題目輸入保證每個測試存在唯一解。

輸入樣例:

3485djdkxh4hhge

2984akdfkkkkggedsb

s&hgsfdk

d&hyscvnm

輸出樣例:

thu 14:04

###題目分析

1.題目比較長,要能找到有用資訊。

2.周一到週日由「a" ~ 「g」(大寫) 表示,第一步就是找到前兩個字串第一對相同的大寫字母,找到之後跳出,不再重複進行。

3.第二步就是找到前兩個字串第二對相同字元,表示小時。相同字元是 『0』 ~ 『9』 則表示0點到9點,相同字元 『a』 到 』n』 ,則表示10點到23點。找到之後跳出,不再重複進行。

4.第三步就是找出後兩個字串第一對相同英文本母他們的位數表示分鐘數,範圍0~59。找到之後跳出,不再重複進行。

5.因為有時間的輸出,所以在輸出的時候printf("%02d",min);可以以hh:mm的形式輸出。

###ac

#include

#include

#include

intmain()

//小時

if(ch[0]

[i]== ch[1]

[i]&& flag==0&&

((ch[0]

[i]>=

'a'&&ch[0]

[i]<=

'n')

||(ch[0]

[i]>=

'0'&&ch[1]

[i]<=

'9')))

}//輸出小時

if(hour>=

'0'&&hour<=

'9')

printf

("%02d:"

,hour-

'0')

;else

printf

("%02d:"

,hour-

'a'+10)

;//分鐘

int min=0;

int b=

strlen

(ch[2]

)<=

strlen

(ch[3]

)?strlen

(ch[2]

):strlen

(ch[3]

);for(

int i=

0;i//輸出分鐘

printf

("%02d\n"

,min)

;return0;

}

1014 福爾摩斯的約會(20 分)

1014 福爾摩斯的約會 20 分 大偵探福爾摩斯接到一張奇怪的字條 我們約會吧!3485djdkxh4hhge 2984akdfkkkkggedsb s hgsfdk d hyscvnm。大偵探很快就明白了,字條上奇怪的亂碼實際上就是約會的時間星期四 14 04,因為前面兩字串中第 1 對相同的大...

1014 福爾摩斯的約會(20 分)

include using namespace std int main int flag 0 cin a b c d for int i 0 i a a i g flag cout a a i n flag if isdigit a i printf 02d a i 0 else cout 101...

1014 福爾摩斯的約會(20 分)

1014 福爾摩斯的約會 20 分 大偵探福爾摩斯接到一張奇怪的字條 我們約會吧!3485djdkxh4hhge 2984akdfkkkkggedsb s hgsfdk d hyscvnm。大偵探很快就明白了,字條上奇怪的亂碼實際上就是約會的時間星期四 14 04,因為前面兩字串中第 1 對相同的大...