1. 程式人生 > >[C/C++] 1014 福爾摩斯的約會 (20)(20 分)

[C/C++] 1014 福爾摩斯的約會 (20)(20 分)

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; }