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

Github代碼(不全,更新中)

分析:【第一對相同的大寫英文字母,包括A-G】,【第二對相同的字符,包括0-9,A-N】,【第三對相同的英文字母,包括大小寫】,只要不踩坑,題目還是挺容易的......

PS:限定字符的範圍時,千萬千萬不要忘記寫等號!!!比如ch<='a',不要寫出ch<'a'!!!

#include <iostream>
#include <cstdio>

using namespace std;
string week[8] = {"MON", "TUE", "WED", "THU", "FRI", "SAT","SUN"};
int main()
{
    string str[4];
    int len[4];
    for(int i=0; i<4; i++){
        cin>>str[i];
        len[i] = str[i].length();
    }

    int limit1 = len[0]<=len[1]?len[0]:len[1];
    int limit2 = len[2]<=len[3]?len[2]:len[3];

    int time=1;
    for(int i=0; i<limit1; i++){
        if(time == 1 && str[0][i] == str[1][i]){
            if(str[0][i] >= 'A' && str[0][i] <= 'G'){
                cout<<week[(str[0][i]-'A')]<<" ";
                time++;
            }
        } else if(time == 2 && str[0][i] == str[1][i]){
            if(str[0][i] >= '0' && str[0][i] <= '9'){
                cout<<'0'<<(str[0][i] - '0')<<":";
                break;
            } else if(str[0][i] >= 'A' && str[0][i] <= 'N'){
                cout<<(str[0][i] - 'A' + 10)<<":";
                break;
            }
        }
    }

    for(int i=0; i<limit2; i++){
        if(str[2][i] == str[3][i]&&((str[2][i]>='a'&&str[2][i]<='z')||(str[2][i]>='A'&&str[2][i]<='Z'))){
            printf("%02d\n", i);
            break;
        }
    }
    return 0;
}

 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章