[PAT乙] 1014. 福尔摩斯的约会 (20)

来源:互联网 发布:网络综艺访谈节目 编辑:程序博客网 时间:2024/05/17 04:01

大侦探福尔摩斯接到一张奇怪的字条:“我们约会吧! 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


此题充分说明,简单的题目也需要审题!
countA 此变量什么作用呢?我们知道要寻找第一个相同的大写字母,此时,要确保之后相同的不能被覆盖,所以可以看作一个开关变量,初始置零,找到第一个置非零,用作条件即可。
Switch也是如此,不过值得一提的是,switch状态改变后,应该continue一下,毕竟寻找的是下一个。
最值得一提的是,题目中隐含的条件。原本我写作这样:

if((isupper(s[i]) && s1[i]==s2[i])

想一想这里怎么不对呢,的确,题目要求找到第一个相同的大写字母。可是隐含的说它是便是星期几的,一次,s[i] 有范围!,盲目使用<cctype> 或 <ctype.h> 极有可能造成一时半会想不到的错误,因此,不如直接借用对数值的控制。

#include <iostream>#include <string>#include <vector>#include <cctype>using namespace std;typedef string::size_type sizet;int main() {    string s1, s2, s3, s4;    int week, hour, min;    vector<string> s{"MON", "TUE", "WED", "THU", "FRI", "SAT", "SUN"};    cin>>s1>>s2>>s3>>s4;    int countA = 0, countB=0, Switch =0;    for(sizet i=0; i<s1.size() && i<s2.size(); ++i) {        if(countA==0) {            if((s1[i]>='A' && s1[i]<='G') && s1[i]==s2[i]) {                week = (int)(s1[i] - 'A') + 1;                countA++;                Switch=1;                continue;            }        }        if(Switch) {            if(s1[i]==s2[i]) {                if((s1[i]>='A' && s1[i]<='N') || isdigit(s1[i])) {                    if(isupper(s1[i])) hour = (int)(s1[i]-'A') + 10;                    else hour = (int)(s1[i]-'0');                    break;                }             }        }    }    for(sizet i=0; i<s3.size() && i<s4.size(); ++i) {        if(isalpha(s3[i]) && s3[i]==s4[i]) {            min = i;        }    }    cout << s[week-1] <<' ';    printf("%0.2d:%0.2d", hour, min);    return 0;}