//1014 福尔摩斯的约会(20 分)
//大侦探福尔摩斯接到一张奇怪的字条:我们约会吧! 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
C:
#include <stdio.h>
#include <math.h>
int main(int argc, const char * argv[]) {
char str1[61],str2[61],str3[61],str4[61];
scanf("%s %s %s %s",str1,str2,str3,str4);
char* week[7] = {"MON","TUE","WED","THU","FRI","SAT","SUN"};//对应A-G
//DAY
int DAY = 0;
for (DAY = 0; str1[DAY] && str2[DAY]; DAY++) {
//str1[DAY] && str2[DAY] 等价于 str1[DAY] != '\0' && str2[DAY] != '\0'
if (str1[DAY] == str2[DAY] && str1[DAY] >= 'A' && str1[DAY] <= 'G') {
printf("%s ",week[str1[DAY] - 'A']);
break;
}
}
//HH
for (int HH = DAY + 1; str1[HH] && str2[HH]; HH++) {
if (str1[HH] == str2[HH]) {
if (str1[HH] >= 'A' && str1[HH] <= 'N') {
printf("%02d",str1[HH] - 'A' + 10);
break;
}else if(str1[HH] >= '0' && str1[HH] <= '9')
{
printf("%02d",str1[HH] - '0');
break;
}
}
}
//MM
for (int MM = 0; str3[MM] && str4[MM]; MM++) {
if (str3[MM] == str4[MM] && str3[MM] >= 'A' && str3[MM] <= 'z') {
printf(":%02d",MM);
break;
}
}
return 0;
}
1.DAY:前两个字符串中第1对相同的大写英文字母,这里注意是大写英文字母
2.HH:第2对相同的字符(0-9或A-N)
3.MM:后两个字符串第1对相同的英文字母出现位置,注意是英文字母,在区分大小写的情况下,取出位置
OliverLew大神很喜欢用索引,而不是像其他博客中使用switch case。
网友评论