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
解题思路:其实就是基本的字符串的操作,但是将代码和在一起会很繁琐而且容易出错,分模块来写。
一,字符变星期
二,字符变小时
三,比较前两串
四,比较后两串
五,主程序
输入格式:
输入在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; }
相关文章推荐
- JDBC数据库连接
- jQuery UI基础----14jQuery UI Widgets-spinner(下拉框
- [LeetCode 214] Shortest Palindrome
- 楼继伟清华演讲全文:中高速增长的可能性及实现途径
- POJ 2236 Wireless Network 并查集
- UVA_12096: The SetStack Computer
- 近期目标
- 杭电acm2566
- jQuery UI基础----13jQurey UI Widgets-slider(滑动器
- 康托展开
- codeforces 583 D. Once Again... (LIS + 贪心)
- jQuery UI基础----12jQuery UI Widgets-menu(菜单
- 《Hacking Vim》读书笔记:Vim中高级技巧
- Socket编程基础之服务端与客户端简单通信
- Android-SharePreference工具类实现
- hdu 3967 数位dp
- jQuery UI基础----11jQuery UI Widgets-progressbar(进度条
- jQuery UI基础----10jQuery UI Widgets-Dialog(对话框
- please select a valid interpreter
- Activity加载模式