大侦探福尔摩斯接到一张奇怪的字条:“我们约会吧! 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
#include<iostream>
#include<string>
#include<ctype.h>
#include<iomanip>
using namespace std;
string WEEK[8] = { "MON ","TUE ","WED ","THU ","FRI ","SAT ","SUN " };
int main()
{
string in_1, in_2, in_3, in_4;
cin >> in_1 >> in_2 >> in_3 >> in_4;
int pos_week = 0, hour = 0, minute = 0;
//星期
int i = 0;
for (;;++i)
{
if (in_1[i] == in_2[i] && in_1[i] >= 'A'&&in_1[i] <= 'G')
{
pos_week = in_1[i] - 'A';
//避免找hour时被误识
in_1[i] = 'a';
in_2[i] = 'b';
break;
}
}
//hour
for ( ++i;; ++i)
{
if (in_1[i] == in_2[i]&&((in_1[i] >= 'A'&&in_1[i] <= 'N')||(in_1[i] >= '0'&&in_1[i] <= '9')) )
{
if (isalpha(in_1[i]))
hour = in_1[i] - 'A' + 10;
else
hour = in_1[i] - '0';
break;
}
}
//minute
for (i = 0;; ++i)
{
if (in_3[i] == in_4[i]&&isalpha(in_3[i]))
{
minute = i;
break;
}
}
cout << WEEK[pos_week];
cout << hour / 10 << hour % 10 << ':';
cout << minute / 10 << minute % 10;
//cout << setfill('0') << setw(2) << hour << ':';
//cout << setw(2) << minute;
system("pause");
return 0;
}
末尾的代码:把7用07来输出的两种方法;找输出格式的时候用到了个网站,挺好用的,推荐一下http://www.cplusplus.com/reference/clibrary/
题目中的“题目输入保证每个测试存在唯一解。”真是误我已久。哎。没办法,谁让我要刷他的题呢。
注意A~N,A~G