本文只是本人刷题途中写的小总结用于日后自身复习,如有错误欢迎指出~
题目分析
- Sherlock解码破案,从四个字符串中解码得出约会时间。 找出头两个字符串的第一个相同的大写字母(case sensitive)来确定星期几
- 找出头两个字符串的继第一个相同大写字母后的相同字符(character:可以是数字也可以是字母)来确定时钟数
- 找出后两个字符串的第一个相同的字母(不区分大小写)来确定分钟数
注意点
- 大小写不要弄混
- 步骤1和2中由于一星期只有七天和二十四小时的限制不可以完整的纳入A~Z字母
我的代码
代码思路和debug历程
头两个字符串和后两个字符串分别进行扫描找到需要找出的相同字符。用flag来确定头两个字符串中第一个相同的大写字母有没有被找到。
后来提交有测试点过不了发现是有个if分支里少写了break导致(憨憨如我ヽ(ー_ー)ノ)输出了时钟数还会继续进行循环扫描输出,修改后就通过了。
代码
#include<iostream>
#include<string>
using namespace std;
int main()
{
string s1, s2, s3, s4;
string days[] = { "MON","TUE","WED","THU","FRI","SAT","SUN" };
cin >> s1 >> s2 >> s3 >> s4;
int length = s1.size() < s2.size() ? s1.size() : s2.size();
int flag = 0;
for (int i = 0; i < length; i++) {
if (s1[i] >= 'A'&&s1[i] <= 'G'&&flag == 0) {//易错点:暗藏第一个相同大写字母必须为A-G
if (s1[i] == s2[i]) {
cout << days[s1[i] - 'A'] << ' ';
flag++;
}
}
else if (s1[i] == s2[i]&& flag != 0) {
if(s1[i] >= '0'&&s1[i] <= '9'){
cout << '0' << s1[i] << ':';
break;//易错点:必须要加break不然容易找到了接着继续找
}
else if (s1[i] >= 'A'&&s1[i] <= 'N') {
cout << s1[i] - 'A' + 10 << ':';
break;
}
}
}
length = s3.size() < s4.size() ? s3.size() : s4.size();
for (int i = 0; i < length; i++) {
if ((s3[i] >= 'a'&&s3[i] <= 'z') || (s3[i] >= 'A'&&s3[i] <= 'Z')) {
if (s3[i] == s4[i]) {
if (i < 10)
cout << '0' << i;
else
cout << i;
}
}
}
return 0;
}
dalao代码(柳神的)
额因为版权还有格式问题,代码就不全放了,说一些可以借鉴的优美代码点吧~
借鉴点
- 采用把i提出来,来实现找出第一个大写字母后接着找相同的字符
- 用isdigit()来判断是否是数字0~9
- 用isalpha()来判断是否是字母(大写和小写都为true)
- 输出的时候采用printf("%02d",mm);可以实现一位数前面0的补全,用printf来输出类似时间之类的又有符号又要补全的还是很方便的~