1004福尔摩斯的约会 (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表示星期日。题目输入保证每个测试存在唯一解。
 

#include
#include
#include
#include
#include

using namespace std;

map day= {
	{
		'A',"MON"
	},
	{
		'B',"TUE"
	},
	{
		'C',"WED"
	},
	{
		'D',"THU"
	},
	{
		'E',"FRI"
	},
	{
		'F',"SAT"
	},
	{
		'G',"SUN"
	},
};

void func(string s1,string s2,string s3,string s4) {
	int len1,len2;
	char c1;
	int c2,c3;
	//获取字符串长度
	len1=(s1.length()>=s2.length()?s1.length():s2.length());
	len2=(s3.length()>=s4.length()?s3.length():s4.length());
	int i=0;
	for(; i='A'&&s1[i]<='G') {
			c1=s1[i];
			i++;
			break;
		}
	}
	//注意题目要求,在哪个字符串对比取值 
	for(; i='0')) {
				c2=s1[i]-'0';
			} else if(s1[i]<='N'&&s1[i]>='A') {
				c2=s1[i]-'A'+10;
			} else {
				continue;
			}
			break;
		}
	}
	i=0;
	for(; i

注意:

1.能够准确C语言库的使用能够提供效率,比如ctype.h的库里面的判断大写字母的方法等

2.对于条件的判断,一定要根据题目给出的要求分析条件

        例如在星期的判断中,要求大写字母的范围A-G,我开始的时候只是判断是相同字母的情况下为大写字母则为true,过测试样例时出现Y相同的字母,但是在找map对应的星期几出现为空的情况,导致输出的结果错误。

3.注意字符串输入输出的方式

        输入可以使用scanf方法接收字符串:

char strs[4][61];
scanf("%s%s%s%s", strs[0], strs[1], strs[2], strs[3]);

        

你可能感兴趣的:(pat,c++,算法,pat考试)