1014 福尔摩斯的约会
分析:
1.字符相等,而且字符必须是大写字母,且必须在’A’ ~ ‘G’ 之间。(星期几)
2.字符相等,而且字符必须在’A’ ~ ‘N’ 或 ‘0’ ~ '9’之间 (小时)
3.字符相等, 而且必须是字母。(分钟)
————————————————
版权声明:本文为CSDN博主「legend_456」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/legend_456/article/details/83045408
#include<iostream>
#include<string>
#include<cstring>
using namespace std;
int main()
{
string str1,str2,str3,str4;
cin>>str1>>str2>>str3>>str4;
int len1 =0,len2=0;
int step=0;//标记当前是在找第几个数
char weekday;//存储星期几(这个变量可以省略)
char hour;//储存小时
int minute=0;//储存分钟
len1=str1.length()<str2.length()?str1.length():str2.length();//len1,len2是较短的字符串的长度(两次都是只要一个字符串完结就不用判断了)
len2=str3.length()<str4.length()?str3.length():str4.length();
for(int i=0;i<len1;i++)
{
if((str1[i]==str2[i])&&step==0&&str1[i]>='A'&&str1[i]<='G')//找到第一个匹配的字符并且是在进行第一步(找星期几)而且范围合适
{
weekday=str1[i];//可以直接在switch里面判断str1[i]来省略这个步骤
switch(weekday)//根据字符对应输出是星期几
{
case 'A':cout<<"MON ";break;//注意此处是全大写并且末尾有空格
case 'B':cout<<"TUE ";break;
case 'C':cout<<"WED " ;break;//注意单词拼写,就··错了挺无语的
case 'D':cout<<"THU ";break;
case 'E':cout<<"FRI ";break;
case 'F':cout<<"SAT ";break;
case 'G':cout<<"SUN ";break;
}
step=1;//更新step表明应该进入下一步骤(找几点)
continue;//跳过本轮循环剩余部分,直接进入下一次循环(即判断几点)
}
else if((str1[i]==str2[i])&&step==1&&((str1[i]>='A'&&str1[i]<='N')||(str1[i]>='0'&&str1[i]<='9')))//注意最后条件是或,0-9或者A到N都可以,不能用isUpper()函数
{
//如果搞不清楚逻辑关系就多加几层括号以防万一
hour=str1[i];
break;
}
}
for(int j=0;j<len2;j++)
{
if(str3[j]==str4[j]&&isalpha(str3[j]))//这个字符必须是字母
{
//minute=str3[j]-'0';//这一步错误!
minute=j;//要这样获取数字,通过是第几个字符(从0开始算)一样来求分钟
break;
}
}
if(hour>='0'&&hour<='9')//hour是char类型,要与字符比较
{
cout<<"0"<<hour<<":";
}
else
{
cout<<hour-'A'+10<<":";//hour-A算出个位,然后加10换成24小时制,比如hour=B是11点, B(66)-A(65)的ASCII差就是1,1+10就是11点
}
printf("%02d",minute);//限定2位,不够的用0填满(比如9就打印成09)
}
这道题坑真的挺多的,第一遍照着参考代码敲下来16分,结果发现一个是>=写成了>+,一个是星期三简写WED我写成了WEN···········