PAT(Basic Level) Practice——1014 福爾摩斯的約會
阿新 • • 發佈:2018-11-25
原題目:
大偵探福爾摩斯接到一張奇怪的字條:我們約會吧! 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.按照題意直接找,星期儲存在字元陣列。
程式碼:
C語言版:
#include <stdio.h> #include <stdlib.h> #include <math.h> int main() { char A[70],B[70],C[70],D[70]; int i=0,j=0,k=0,a=0,b,c; char *Str[7]={"MON","TUE","WED","THU","FRI","SAT","SUN"}; gets(A); gets(B); gets(C); gets(D); while(1) { if((A[i]>='A'&&A[i]<='G')||(B[i]>='A'&&B[i]<='G')) { if(A[i]==B[i]) { a=A[i]-'A'; i++; break; } } i++; } while(1) { // if(A[i]>='A'&&A[i]<='N') { if(A[i]==B[i]) { b=A[i]-'A'+1+9;//處理時間,即可直接列印,A[i]的ASCII碼值減去‘A’的,加上10,即為換算出的時間 break; } } else if(A[i]>='0'&&A[i]<='9') { if(A[i]==B[i]) { b=A[i]-'0';//對於數字的直接減去‘0’的即可 break; } } i++; } i=0; while(1) { if((C[i]>='a'&&C[i]<='z')||(C[i]>='A'&&C[i]<='Z')) { if(C[i]==D[i]) { c=i; break; } } i++; } printf("%s %02d:%02d",Str[a],b,c); return 0; }