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

解题思路: 在做这道题的过程当中,我感觉因为题目讲的没有那么的清楚,还有看到这道题的通过率导致这道题目的考虑过于的复杂了,题目当中并没有讲清楚结果在第一行中存在还是有可能在第二行当中存在,我在一开始做的时候,我想的是更加全面的情况,也许在第二行出现日期的情况,我就将整个程序开始往全面做,题目当中也没有说,他这个日期的字母是A到G的,我还在考虑到Z的情况进行取余,这种乱七八糟的错误想法,是整个程序莫名其妙的变得这么大了,但是不得不说现在的程序上的BUG越来越少了,加油加油.

黎明之前总是最黑暗.

//这道题的题意看起来蛮复杂的,实际上没有那么的复杂
//在前俩行当中找出日期和小时,在后来行当中找到分钟,这里要注意找的时候哪一行的数在前哪一行的在后
#include<iostream>
#include<string>
#include<vector>
#include<cctype>
using namespace std;

int swaps(string a, string b)
{
	if (a.size() > b.size()) {
		return 1;
	}
	else
		return 0;
}

int main()
{
	vector<string>arr(4);//输入的一定是四个字符串
	for (int i = 0; i < 4; ++i)
	{
		cin >> arr[i];
	}
	int mide = -1;
	mide = swaps(arr[0], arr[1]);
	if (mide == 1)
	{
		string middle;
		middle = arr[0];
		arr[0] = arr[1];
		arr[1] = middle;
	}
	mide = -1;
	mide = swaps(arr[2], arr[3]);//这里是为了让比较的第一行是个数最小的行
	if (mide == 1)
	{
		string middle;
		middle = arr[2];
		arr[2] = arr[3];
		arr[3] = middle;
	}
	string Day[8] = { "MON","TUE","WED","THU","FRI","SAT","SUN" };//这里存储的是星期几
	char hour[24] = { '0','1','2','3','4','5','6','7','8','9','A','B','C','D','E','F','G','H','I','J','K','L','M','N' };
	//int min = 0;//用来记录分钟
	int flag = 0;//用来记录现在要找的是天数,小时还是分钟,题目当中并没有说这三个东西出现的位置,所以使用这个来统计个数,这个我猜就是这道题的难点吧
	for (int i = 0; i < arr[0].size(); ++i)
	{
		if (arr[0][i] == arr[1][i])
		{
			if ((flag == 0) && (isupper(arr[0][i])))//找的是天数的话
			{
                if(arr[0][i]<='G')
                {
				    flag++;
				    int middle = toupper(arr[0][i]) - 'A';//这里需要将这个元素转换为大写,toupper()可以将大写字母转换为大写的字母,如果原本是大写字母则原数返回
				    middle = middle % 7;
				    cout << Day[middle] << " ";//在这里输出天数
                }
			}
			else if ((flag == 1) && ((arr[0][i]>='0')&&(arr[0][i]<='9')||((arr[0][i]>='A')&&(arr[0][i]<='N'))))
			{
                flag++;
				char middle;
				if (isalpha(arr[0][i]))
					middle = arr[0][i];
				else
					middle = arr[0][i];
				for (int j = 0; j < 24; ++j)
				{
					if (middle == hour[j])
					{
                        if(j<10)
						    cout <<"0"<< j << ":";//在这里判断出来的是输出小时
                        else
                            cout << j << ":";
						break;
					}
				}
			}
			else if ((flag == 2) && (isalpha(arr[0][i])))
			{//这里处理的是分钟
                flag++;
				if (i < 10) {
					cout << "0" << i;
					return 0;
				}
				else
				{
					cout << i;
					return 0;
				}
			}
		}
	}
	for (int i = 0; i < arr[2].size(); ++i)
	{
		if (arr[2][i] == arr[3][i])
		{
            
			if ((flag == 0) && (isupper(arr[2][i])))//找的是天数的话
			{
                if(arr[2][i]<='G')
                {
				    flag++;
				    int middle = toupper(arr[2][i]) - 'A';//这里需要将这个元素转换为大写,toupper()可以将大写字母转换为大写的字母,如果原本是大写字母则原数返回
				    middle = middle % 7;
				    cout << Day[middle] << " ";//在这里输出天数
                }
			}
			else if((flag == 1) && ((arr[2][i]>='0')&&(arr[2][i]<='9')||((arr[2][i]>='A')&&(arr[2][i]<='N'))))
			{
                flag++;
				char middle;
				if (isalpha(arr[2][i]))
					middle = arr[2][i];
				else
					middle = arr[2][i];
				for (int j = 0; j < 24; ++j)
				{
					if (middle == hour[j])
					{
                        if(j<10)
						    cout <<"0"<< j << ":";//在这里判断出来的是输出小时
                        else
                            cout << j << ":";
						break;
					}
				}
			}
			else if ((flag == 2) && (isalpha(arr[2][i])))
			{//这里处理的是分钟
                flag++;
				if (i < 10) {
					cout << "0" << i;
					return 0;
				}
				else
				{
					cout << i;
					return 0;
				}
			}
		}
	}
	return 0;
}

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值