这道题需要注意的一点是星期和小时都在第一和第二个字符串中位置相对应的里面找,找到星期之后一定要保存一下下标并且++,再找小时的时候别再把星期的字符给错误的算上了
#include <iostream>
#include <string>
#include <algorithm>
#include <cctype>
using namespace std;
string true_week[]={"MON","TUE","WED","THU","FRI","SAT","SUN"};
int main()
{
string str1,str2,str3,str4;
cin>>str1>>str2>>str3>>str4;
int i;
string::iterator it;//星期对应的位置
//找星期
for(i=0;i<str1.size();i++){
if(isupper(str1[i])&&str1[i]<='G'&&str1[i]==str2[i]){//如果是相同的大写英文字母并且在A~G之间!!!
cout<<true_week[str1[i]-'A']<<" ";
i++;
break;
}
}
//找小时
for (;i<str1.size();i++) {
if(isupper(str1[i])&&str1[i]<='N'&&str1[i]==str2[i]){//如果是相同的大写英文字母并且在A~N之间!!!
cout<<str1[i]-'A'+10<<":";
break;
}
else if(isdigit(str1[i])&&str1[i]==str2[i]){
cout<<"0"<<str1[i]<<":";
break;
}
}
//找分钟
for(int j=0;j<str3.size();j++){
if(isalpha(str3[j])&&str3[j]==str4[j]){
if(j<10){
cout<<"0"<<j<<endl;
break;
}
else {
cout<<j<<endl;
break;
}
}
}
return 0;
}