题目介绍
大侦探福尔摩斯接到一张奇怪的字条:“我们约会吧! 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()
{
int n,i,x=0,flag1=0,flag2=0;
char a[61],b[61],c[61],d[61];
gets(a);
gets(b);
gets(c);
gets(d);
for(int i = 0; a[i] != '\0'&& b[i] != '\0';i++)
{
if(a[i] == b[i] && flag1==0 && a[i]>='A' && a[i]<='G')
{
flag1 = 1;
flag2 = 1;
if(a[i] == 'A')
printf("MON ");
if(a[i] == 'B')
printf("TUE ");
if(a[i] == 'C')
printf("WED ");
if(a[i] == 'D')
printf("THU ");
if(a[i] == 'E')
printf("FRI ");
if(a[i] == 'F')
printf("SAT ");
if(a[i] == 'G')
printf("SUN ");
continue;
}
if(a[i] == b[i] && flag2==1)
{
if(a[i]>='0' && a[i]<='9')
{
printf("%02d:",a[i]-'0');
break;
}
if(a[i]>='A'&& a[i]<='N')
{
printf("%02d:",a[i]-55);
break;
}
}
}
for (i=0;c[i]!='\0' && d[i]!='\0';i++)
{
if (c[i]==d[i] && isalpha(c[i]))
{
printf("%02d",i);
break;
}
}
return 0;
}
知识分析
知识一
#include<ctype.h>
介绍:
1.字符测试函数
函数原型均为int isxxxx(int)
参数为int, 任何实参均被提升成整型
只能正确处理处于[0, 127]之间的值
2.字符映射函数
函数原型为int toxxxx(int)
对参数进行检测, 若符合范围则转换, 否则不变
int tolower(int); ‘A’~’Z’ ==> ‘a’~’z’
int toupper(int); ‘a’~’z’ ==> ‘A’~’Z’
知识二
printf("%02d",i);
%2d是将数字按宽度为2,采用右对齐方式输出,若数据位数不到2位,则左边补空格。
%02d,和%2d差不多,只不过左边补0。