当前位置: 代码迷 >> 综合 >> 【C语言版】1014?福尔摩斯的约会?(20分)
  详细解决方案

【C语言版】1014?福尔摩斯的约会?(20分)

热度:3   发布时间:2023-12-25 11:24:55.0

 

大侦探福尔摩斯接到一张奇怪的字条:我们约会吧! 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>
int main()
{char string[4][60],day,HH,MM;char DAY[7][4]={"MON","TUE","WED","THU","FRI","SAT","SUN"};//A-Nint i=0,j=0;for(i=0;i<4;i++)//输入四个字符串 scanf("%s",string[i]);for(i=0;i<60;i++)//寻找星期几  HH{if((string[0][i] == string[1][i]) && j==0 && (string[0][i]>='A') && (string[0][i]<='G') ){//条件:前面两行字符串 找到第一个相同的字母,只能是大写字母: A-G day=string[0][i];//A-G:1-7j++;continue;}if(((string[0][i] == string[1][i]) && j==1) && ( ((string[0][i]>='A') && (string[0][i]<='N')) || ((0<=string[0][i]) && (string[0][i] <=9))) ){//条件:在前面的基础上 ,在找到相同的第二个字母A-N或0-9都可以的 HH=string[0][i];//0-9--A-N : 0-23j++; }if(j==2)break;}	for(i=0;i<60;i++)//寻找MM{if((string[2][i] == string[3][i]) && (((string[2][i]>='a') && (string[2][i]<='z')) || ((string[2][i]>='A') && (string[2][i]<='Z'))) ){//条件:最后两行找到相同位置的字母(大小均可),然后记录才index  break 退出循环 MM=i;break;}}printf("%s ",DAY[day-'A']);//星期的输出 if(HH<='9')//小时的输出 printf("%02d:",HH);//%02d:如果不足两位,用0补齐else printf("%d:",(HH-'A'+10));printf("%02d",MM);//分钟的输出 return 0; 
}

测试点2不知道为什么就是过不去,等后面有时间了再重新看看。。。