您的位置:首页 > 其它

PAT1014 福尔摩斯的约会

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

解题思路:其实就是基本的字符串的操作,但是将代码和在一起会很繁琐而且容易出错,分模块来写。

一,字符变星期

string letter2week(char tag){
string week[7] = { "MON", "TUE", "WED", "THU", "FRI", "SAT", "SUN" };
int t = int(tag) - 64;
return week[t - 1];
}


二,字符变小时

int letter2hour(char tag){
int t = (int)tag - 64 + 9;
return t;
}


三,比较前两串

char *findWeek(string str1,string str2){
char tag[2];
bool flag1 = false;
int len1 = str1.length(),len2=str2.length(),c=1,k1=0,k2=0;
for (int i = 0; i < len1; ++i){
tag[0] = str1[i];
if (isupper(tag[0]))
{
for (int j = 0; j < len2; ++j){
if (str2[j] == tag[0]){ flag1 = true; ++c; k1 = i;k2=j; break; }
}
}
if (flag1)break;
}
flag1 = false;
if (c == 2){
for (int i = k1+1; i < len1; ++i){
tag[1] = str1[i];
if (isupper(tag[1]))
{
for (int j = k2+1; j < len2; ++j){
if (str2[j] == tag[1]){ flag1 = true; ++c; k1 = i; k2 = j; break; }
}
}
if (flag1)break;
}
}

return tag;
}


四,比较后两串

int findMins(string str1, string str2){
char tag;
int len1 = str1.length(), len2 = str2.length(),k=0;
bool flag = false;
for (int i = 0; i < len1; ++i){
tag = str1[i];
if (isalpha(tag)){
for (int j = 0; j < len2; ++j){
if (tag == str2[j]){ k = j; flag = true; k = j; break; }
}
}
if (flag)break;
}
return k;
}


五,主程序

int main(){
string str1 = "3485djDkxh4hhGE", str2 = "2984akDfkkkkggEdsb";
string str3 = "s&hgsfdk", str4 = "d&Hyscvnm";
char *tag;
tag = findWeek(str1, str2);
char week = tag[0], hour = tag[1];
cout <<letter2week(week) << " " << letter2hour(hour)<< ":";
int mins = findMins(str3, str4);
if (mins < 10)cout << "0" << mins << endl;
else cout << mins << endl;
return 0;
}


第二种方法


int funs(char x){
int result = 0;
if (x >= '0'&&x <= '9')result = (x - '0');
if (x >= 'A'&&x <= 'N')result = (x - 'A') + 10;
return result;
}
void PATexe(){
string str[4] = {"3485djDkxh4hhGE", "2984akDfkkkkggEdsb", "s&hgsfdk", "d&Hyscvnm"};
string week[7] = { "MON", "THE", "WED", "THU", "FRI", "SAT", "SUN" };
int lenstr[4] = { 0 },k=0;
char tmp[2];

bool a = false,b=false;
for (int i = 0; i < 4; ++i){
lenstr[i] = str[i].length();
}
for (int i = 0; i < lenstr[0]; ++i){
if (!isupper(str[0][i]))continue;
for (int j = 0; j < lenstr[1]; ++j){
if (str[0][i] == str[1][j] && isupper(str[0][i]) ){ tmp[k++] = str[0][i];}
}
}
cout << week[tmp[0] - 'A'] << " ";
k = funs(tmp[1]);
k<10 ? cout << '0' << k : cout << k;
cout <<':';

k = 0;
while (k<lenstr[2])
{
if (str[2][k] == str[3][k]&&isalpha(str[2][k])){ break; }
else ++k;
}
k<10 ? cout << '0' << k : cout << k;
cout << endl;
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: