专栏首页程序员PAT(乙级)1014

PAT(乙级)1014

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

这道题目,略显(真TM坑爹,抱歉,我又说脏话了,但是实在不能忍啊!!!)坑爹。题目的意思看起来说的很清楚,实则完全没有说清楚,题目是“横看成岭侧成峰”啊!,但是标准答案只有一个。哎,等会了写篇文章总结一下刷了10多篇后的体会。这里就不废话了(感觉已经废话已经有点多了,哈哈)。重点来了。

首先,第一个确定的星期几的问题,这个要求必须是大写字母,即:if ('A' <= str[0][i] && str[0][i] <= 'G')

第二,这个题目就表达的没什么问题了,要求是数字或者大写字母,即:

if (str[0][i] == str[1][i] && (str[0][i] >= '0' && '9' >= str[0][i]))或者是if (str[0][i] == str[1][i] && ('A' <= str[0][i] && str[0][i] <= 'N'))两种情况

第三,这个也很坑,实质的要求是,只能是字母。即:if (('a' <= str[2][i] && 'z' >= str[2][i]) || ('A' <= str[2][i] && str[2][i] <= 'Z'))

好了,上代码:

#define _CRT_SECURE_NO_WARNINGS
#include<stdio.h>
#include<string.h>
#include<stdlib.h>

int main()
{
	char str[4][60];
	char day[7][4] = { "MON","TUE","WED","THU","FRI","SAT","SUN" };
	int k = 0;
	int num1 = 0, num2 = 0;
	for (int i = 0; i < 4; i++)
	{
		scanf("%s", &str[i]);
	}
	for (int i = 0; i < strlen(str[0]); i++)
	{
		if (str[0][i] == str[1][i])
		{
			if ('A' <= str[0][i] && str[0][i] <= 'G')
			{
				num1 = str[0][i] - 65;		//确定星期
				k = i;
				break;
			}
		}
	}
	for (int i = k + 1; i < strlen(str[0]); i++)
	{
		if (str[0][i] == str[1][i] && (str[0][i] >= '0' && '9' >= str[0][i]))
		{
			num2 = str[0][i] - '0';		//确定小时
			break;
		}
		if (str[0][i] == str[1][i] && ('A' <= str[0][i] && str[0][i] <= 'N'))
		{
			num2 = str[0][i] - 'A' + 10;		//确定小时
			break;
		}
	}
	for (int i = 0; i < strlen(str[2]); i++)
	{
		if (str[2][i] == str[3][i])
		{
			if (('a' <= str[2][i] && 'z' >= str[2][i]) || ('A' <= str[2][i] && str[2][i] <= 'Z'))
			{
				k = i;
				break;
			}
		}
	}
	printf("%s ", day[num1]);
	if (num2 < 10)
	{
		printf("0%d:", num2);
	}
	else
	{
		printf("%d:", num2);
	}
	if (k < 10)
	{
		printf("0%d", k);
	}
	else
	{
		printf("%d", k);
	}

	system("pause");
	return 0;
}

忘记说明了,补在这里,代码是在VS2015下测试的,为了使用scanf这个函数,在代码第一行加入了一个宏命令。system("pause")是为了让界面卡一下,方便看输出。当然了,我在最后的输出格式上做的不太好,其实后面的小时和分钟,可以使用相同的一个函数,能少写点代码。然后,就没有然后了。

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • Linux进程间通信——匿名管道

    版权声明:本文为博主原创文章,转载请注明博客地址: https://blog.csdn.ne...

    zy010101
  • 函数umask

    函数umask为进程设置权限掩码。并且返回之前的掩码值。它是为数不多的没有出错返回的函数。函数原型和依赖的头文件如下所示:

    zy010101
  • 守护进程

    守护进程(daemon)是一类在后台运行的特殊进程,用于执行特定的系统任务。很多守护进程在系统引导的时候启动,并且一直运行直到系统关闭。另一些只在需要的时候才启...

    zy010101
  • python内置模块之string

    str.capitalize() 把字符串的第一个字符大写 str.center(width) 返回一个原字符串居中,并使用空格填充到width长度的...

    菲宇
  • Javascript字符串常用方法详解

    => 返回字符串的第 n 个字符,如果不在 0~str.length-1之间,则返回一个空字符串。

    前端博客 : alili.tech
  • 去除字符数组中指定的字符

    Winter_world
  • 5.QT-QString类

    张诺谦
  • C#字符串截取

    yaphetsfang
  • [剑指offer] 字符串的排列

    输入一个字符串,按字典序打印出该字符串中字符的所有排列。例如输入字符串abc,则打印出由字符a,b,c所能排列出来的所有字符串abc,acb,bac,bca,c...

    尾尾部落
  • LeetCode 709. 转换成小写字母

    实现函数 ToLowerCase(),该函数接收一个字符串参数 str,并将该字符串中的大写字母转换成小写字母,之后返回新的字符串。

    Michael阿明

扫码关注云+社区

领取腾讯云代金券