1014. 福尔摩斯的约会 (20)
时间限制
50 ms
内存限制
32000 kB
代码长度限制
8000 B
判题程序
Standard
作者
CHEN, Yue
大侦探福尔摩斯接到一张奇怪的字条:“我们约会吧! 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
/************************************************************************8 @ author : minquan gao @ data : 2014 - 2- 21 @ mail : ensoleilly@gmail.com ************************************************************************/ #include<iostream> #include<string> using namespace std; struct DayInfo{ string day; int hour; }; DayInfo getDayAndHour(string s1,string s2); void printMin(string s1,string s2); int main(){ const int N = 4; string codes[N]; for(int i = 0; i<N; i++){ string input; cin>>input; codes[i] = input; } DayInfo dayInfo = getDayAndHour(codes[0],codes[1]); cout<<dayInfo.day<<" "; if(dayInfo.hour<10){ cout<<"0"<<dayInfo.hour<<":"; }else{ cout<<dayInfo.hour<<":"; } printMin(codes[2],codes[3]); return 0; } DayInfo getDayAndHour(string s1,string s2){ string days[] = {"MON","TUE","WED","THU","FRI","SAT","SUN"}; bool findHour = false; const int DAY_NUM = 7; char start = 'A', end = 'A'+DAY_NUM-1; char startNum = start, endNum = end; char findDayChar = '\0'; char findHourChar = '\0'; for(int i = 0; i<s1.length()&&i<s2.length(); i++){ if((s1[i]>=start && s1[i]<=end) || (s1[i]>=startNum && s1[i]<=endNum)){ char tempChar = s1[i]; if(s2[i] == tempChar){ if(!findHour){ findDayChar = tempChar; findHour = true; startNum = '0'; endNum = '9'; end = 'N'; continue; }else{ findHourChar = tempChar; break; } } } } DayInfo dayInfo; int delta1 = (int)(findDayChar - 'A'); dayInfo.day = days[delta1]; int delta2 = 0; if(isdigit(findHourChar)){ delta2 = (int)(findHourChar - '0'); dayInfo.hour = delta2; }else if(isalpha(findHourChar)){ delta2 = (int)(findHourChar - 'A'); dayInfo.hour = 10 + delta2; } return dayInfo; } void printMin(string s1,string s2){ int min = 0; for(int i = 0; i<s1.length(); i++){ if(isalpha(s1[i])){ if(s2[i] == s1[i]){ min = i; break; } } } if(min<10){ cout<<"0"<<min; }else{ cout<<min; } cout<<endl; //if the question not make the end space clearly, have or not both okay }