题目描述
大侦探福尔摩斯接到一张奇怪的字条:“咱们约会吧! 3485djDkxh4hhGE 2984akDfkkkkggEdsb s&hgsfdk d&Hyscvnm”。大侦探很
快就明白了,字条上奇怪的乱码实际上就是约会的时间“星期四 14:04”,由于前面两字符串中第1对相同的大写英文字母(大小写有区分)是
第4个字母'D',表明星期四;第2对相同的字符是'E',那是第5个英文字母,表明一天里的第14个钟头(因而一天的0点到23点由数字0到九、
以及大写字母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<stdlib.h>
//#include<string.h>
//#include<string>
//#include <cstdlib>
//using namespace std;
#define MIN(x,y) ((x)<(y))?x:y
#define STRLEN 60
int timer[3];
int count=0;
void compare(char *s1,char *s2,int num)
{
int i;
for(i=0;*s1!=NULL&&*s2!=NULL&&count<num;i++,s1++,s2++){
if(*s1==*s2)
switch(count){
case 0:
if(s1[0]>='A'&& s1[0]<='Z')
timer[count++]=s1[0]-'A'+1;
break;
case 1:
if(s1[0]>='0'&& s1[0]<='9')
timer[count++]=s1[0]-'0';
else if(s1[0]>='A'&& s1[0]<='O')
timer[count++]=s1[0]-'A'+10;
break;
case 2:
if((s1[0]>='a'&& s1[0]<='z')||(s1[0]>='A'&& s1[0]<='Z'))
timer[count++]=i;
default:
break;
}
}
}
int main()
{
char s1[STRLEN],s2[STRLEN],s3[STRLEN],s4[STRLEN];
scanf("%s",s1);
scanf("%s",s2);
scanf("%s",s3);
scanf("%s",s4);
//printf("%s %s %s %s",s1,s2,s3,s4);
compare(s1,s2,2);
compare(s3,s4,3);
//printf("%d %d %d",timer[0],timer[1],timer[2]);
switch(timer[0]){
case 1:
printf("MON %02d:%02d\n",timer[1],timer[2]);
break;
case 2:
printf("TUE %02d:%02d\n",timer[1],timer[2]);
break;
case 3:
printf("WED %02d:%02d\n",timer[1],timer[2]);
break;
case 4:
printf("THU %02d:%02d\n",timer[1],timer[2]);
break;
case 5:
printf("FRI %02d:%02d\n",timer[1],timer[2]);
break;
case 6:
printf("SAT %02d:%02d\n",timer[1],timer[2]);
break;
case 7:
printf("SUN %02d:%02d\n",timer[1],timer[2]);
break;
default :
break;
}
return 0;
}