[C/C++] 1014 福爾摩斯的約會 (20)(20 分)
阿新 • • 發佈:2019-02-15
1014 福爾摩斯的約會 (20)(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
關鍵點就在於對於題目細節的理解:星期一共有7個字母,所以不能用全部的26個英文字母判斷。同理,小時也是如此。而且,星期和小時的字母必須大寫,分鐘的可以小寫。
再就是:處理好判斷語句的分支結構,不必太複雜,不然自己也繞裡邊去了。
#include<stdio.h>
#include<string.h>
int main()
{
char wh1[60],wh2[60],m1[60],m2[60];
scanf("%s%s%s%s",wh1,wh2,m1,m2);
char week[7][4] = {"MON","TUE","WED","THU","FRI","SAT","SUN"};
int a = strlen(wh1),b = strlen(wh2);
int cnt = 0;//用來區分第一對字串的兩個相同字母
for(int i = 0;i<a&&i<b;i++) {//星期幾
if(wh1[i] == wh2[i]) {
if(cnt == 0) {
if(wh1[i]>='A'&&wh1[i]<='G'){
printf("%s ",week[wh1[i]-'A']);
cnt++;
}
}
else if(cnt == 1) {//小時
if(wh1[i]>='0'&&wh1[i]<='9') {
printf("%02d:",wh1[i]-'0');break;
}
if(wh1[i]>='A'&&wh1[i]<='N') {
printf("%d:",wh1[i]-'A'+10);break;
}
}
}
}
for(int i = 0;;i++) {//分鐘
if(m1[i] == m2[i]) {
if((m1[i]>='A'&&m1[i]<='Z')||(m1[i]>='a'&&m1[i]<='z')) {
printf("%02d",i);
break;
}
}
}
return 0;
}