1014 福尔摩斯的约会

学习让我浑身难受

1014 福尔摩斯的约会

大侦探福尔摩斯接到一张奇怪的字条:

我们约会吧! 
3485djDkxh4hhGE 
2984akDfkkkkggEdsb 
s&hgsfdk 
d&Hyscvnm

大侦探很快就明白了,字条上奇怪的乱码实际上就是约会的时间星期四 14:04,因为前面两字符串中第 1 对相同的大写英文字母(大小写有区分)是第 4 个字母 D,代表星期四;第 2 对相同的字符是 E ,那是第 5 个英文字母,代表一天里的第 14 个钟头(于是一天的 0 点到 23 点由数字 0 到 9、以及大写字母 AN 表示);后面两字符串第 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 arr1[61];
	char arr2[61];
	char arr3[61];
	char arr4[61];
	gets(arr1);
	gets(arr2);
	gets(arr3);
	gets(arr4);
	char week[7][4] = {"MON","TUE","WED","THU","FRI","SAT","SUN"};
	int day;
	int hour;
	int min;
	int mode = 1;
	for (int i = 0; arr1[i] != '\0' && arr2[i] != '\0'; i++)
	{
		if (mode == 2 && arr1[i] == arr2[i] && ((arr1[i] > 64 && arr1[i] < 79) || (arr1[i] > 47 && arr1[i] < 58)))
		{
			if (arr1[i] > 64)
			{
				hour = arr1[i] - 55;
			}
			else
			{
				hour = arr1[i] - 48;
			}
			break;
		}

		if (mode == 1 && arr1[i] == arr2[i] && arr1[i] > 64 && arr1[i] < 72)
		{
			day = arr1[i]-64;
			mode = 2;
		}

	}
	for (int i = 0; arr3[i] != '\0' && arr4[i] != '\0'; i++)
	{
		if (arr3[i] == arr4[i] && ((arr3[i] > 64 && arr4[i] < 91) || (arr3[i] > 96 && arr4[i] < 123)))
		{
			min = i;
		}
	}
	printf("%s ", week[day-1]);
	printf("%02d:", hour);
	printf("%02d", min);
}

总结:

  1. 注意准确的范围
  2. 用mode1/2来区分第一次相同和第二次
  3. mode2的判断反而要先执行,不然mode1执行完,给mode置2,直接又执行mode2去了
  4. 执行完了记得break,不然后面还有,给第一次的值覆盖了
posted @ 2022-03-30 22:08  huigugu  阅读(31)  评论(0编辑  收藏  举报