PAT乙级 1014 福尔摩斯的约会
题目分析很多,不再赘述。以后在分析题目时,应该一开始就考虑到这些细节。
测试点4 测试用例应该是星期出错,需要保证第一对相同的字符在A到G中间
测试点1、2 应该是保证小时与分钟数均为两位
这里有一个易错点,即判断小时的范围也为0~9, A~N
代码如下:
#include<iostream>
#include<string>
#include<ctype.h>
using namespace std;
string weekdays[7] = {"MON", "TUE","WED","THU","FRI","SAT","SUN"};
int main(){
char s1[60], s2[60], s3[60], s4[60];
int weekday = 0, hh = 0, mm = 0, i, flag1 = 0;
cin>>s1; cin>>s2; cin>>s3; cin>>s4;
for(i = 0; i < 60; i++){
if((s1[i] == s2[i])&&'A' <= s1[i] && s1[i] <= 'G' && 'A' <= s2[i] && s2[i] <= 'G'){
flag1 = i;
weekday = s1[i] - 'A';
break;
}
}
for(i = flag1+1;i < 60;i++){
if( s1[i] == s2[i] && ((s1[i] >= '0' && s1[i] <= '9')||(s1[i] >= 'A' && s1[i] <= 'N'))){
if(s1[i] < 'A') hh = s1[i] - '0';
else hh = s1[i] - 'A' + 10;
break;
}
}
for(i = 0; i < 60;i++){
if(isalpha(s3[i])){
if(s3[i] == s4[i]){
mm = i;
break;
}
}
}
cout<<weekdays[weekday]<<" ";
if(hh < 10) cout<<"0"<<hh<<":";
else cout<<hh<<":";
if(mm < 10) cout<<"0"<<mm;
else cout<<mm;
return 0;
}
最开始的代码,希望用一个循环就解决三对相等的字符串判断,结果导致hh的相同的字符与weekday一样。因此拆成三对循环,让hh的匹配从weekday的匹配之后一个开始进行。