PAT-B 1014. 福爾摩斯的約會 (20)

傳送門

https://pintia.cn/problem-sets/994805260223102976/problems/994805308755394560

題目

大偵探福爾摩斯接到一張奇怪的字條:“我們約會吧! 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.前面兩字符串中第1對相同的大寫英文字母(大小寫有區分),代表星期;
2.前面兩字符串中第2對相同的字符代表小時;
3.后面兩字符串中第1對相同的英文字母出現的位置代表分鐘。

源代碼

//C/C++實現
#include <stdio.h>
#include <iostream>
#include <string.h>

using namespace std;

int main(){
    char a[60], b[60], c[60], d[60];
    char week, hour;
    int minute;
    int equals = 1;
    gets(a);
    gets(b);
    gets(c);
    gets(d);
    int len1 = strlen(a) > strlen(b) ? strlen(b) : strlen(a);
    for(int i = 0; i < len1; i++){
        if(equals == 1){
            if(a[i] >= 'A' && a[i] <= 'G'&& b[i] >= 'A' && b[i] <= 'G'){
                if(a[i] == b[i]){
                    week = a[i];
                    equals++;
                }
            }
        }
        else if(equals == 2){
            if((a[i] >= '0' && a[i] <= '9' || a[i] >= 'A' && a[i] <= 'N') && (b[i] >= '0' && b[i] <= '9' || b[i] >= 'A' && b[i] <= 'N')){
                if(a[i] == b[i]){
                    hour = a[i];
                    break;
                }
            }
        }
    }
    int len2 = strlen(c) > strlen(d) ? strlen(d) : strlen(c);
    for(int j = 0; j < len2; j++){
        if((c[j] >= 'a' && c[j] <= 'z' || c[j] >= 'A' && c[j] <= 'Z') && (d[j] >= 'a' && d[j] <= 'z' || d[j] >= 'A' && d[j] <= 'Z')){
            if(c[j] == d[j]){
                minute = j;
                break;
            }
        }
    }
    switch(week){
        case 'A': printf("MON ");break;
        case 'B': printf("TUE ");break;
        case 'C': printf("WED ");break;
        case 'D': printf("THU ");break;
        case 'E': printf("FRI ");break;
        case 'F': printf("SAT ");break;
        case 'G': printf("SUN ");break;
    }
    if(hour >= '0' && hour <= '9'){
        printf("0%c:", hour);
    }
    else if(hour >= 'A' && hour <= 'N'){
        switch(hour){
            case 'A': printf("10:");break;
            case 'B': printf("11:");break;
            case 'C': printf("12:");break;
            case 'D': printf("13:");break;
            case 'E': printf("14:");break;
            case 'F': printf("15:");break;
            case 'G': printf("16:");break;
            case 'H': printf("17:");break;
            case 'I': printf("18:");break;
            case 'J': printf("19:");break;
            case 'K': printf("20:");break;
            case 'L': printf("21:");break;
            case 'M': printf("22:");break;
            case 'N': printf("23:");break;
        }
    }
    printf("%02d\n", minute);
    return 0;
}
最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。

推薦閱讀更多精彩內容