大侦探福尔摩斯接到一张奇怪的字条:“我们约会吧! 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
这道题遇到最大的坑就是一处代码没有在英文环境下,导致调制了半天。两种方案
#include<stdio.h> #include<ctype.h> int main(){ char str1[65],str2[65],str3[65],str4[65]; char *weekday[] = {"MON","TUE","WED","THU","FRI","SAT","SUN"};int day,hh,mm; //声明要在所有代码之前。不然c-free会报错 gets(str1); gets(str2); gets(str3); gets(str4); for(day = 0;str1[day]&&str2[day];day++){ //第一种访问字符方式 if(str1[day] == str2[day] && str1[day] >= ‘A‘ && str1[day] <= ‘G‘){ printf("%s",weekday[str1[day]-‘A‘]); break; } } //for day for(hh = day+1;str1[hh]&&str2[hh];hh++){ if(str1[hh] == str2[hh]){ if(str1[hh] >= ‘A‘&&str1[hh] <= ‘N‘){ printf(" %d",str1[hh]-‘A‘+10); break; }else if(isdigit(str1[hh])){ printf(" %02d",str1[hh]-‘0‘); break; } }//if }//for hh for(mm = 0;str3[mm]&&str4[mm];mm++){ if(isalpha(str3[mm]) && str3[mm] == str4[mm]){ printf(":%02d",mm); break; } }//for mm return 0; }
#include<stdio.h> #include<string.h> #include<ctype.h> int main(){ char str1[65],str2[65],str3[65],str4[65]; scanf("%s %s %s %s",str1,str2,str3,str4);//输入四个字符串 int i; //找字符串1,2中相同位置的相同字符,代表day char day[][4] = {"MON","TUE","WED","THU","FRI","SAT","SUN"}; for(i = 0;i<strlen(str1); i++) if(str1[i] == str2[i] && str1[i] >= ‘A‘ && str1[i] <= ‘G‘){ printf("%s ",day[str1[i] - ‘A‘]); i++; break; } for(;i < strlen(str1);i++) if(str1[i] == str2[i]){ if(isdigit(str1[i])){ printf("0%c",str1[i]); break; }else if(str1[i] >=‘A‘ && str1[i] <=‘N‘){ printf("%d",str1[i] - ‘A‘ +10); break; } } for(i = 0;i<strlen(str3);i++) if(isalpha(str3[i]) && str3[i] == str4[i]){ printf(":%02d\n",i); break; }
return 0; }