PAT1014 福尔摩斯的约会

文章描述了一个编程挑战,要求根据给定的字符串解码出约会的日期和时间。福尔摩斯接到了一个含有乱码信息的字条,信息通过特定的字符匹配规则编码。解码的关键在于找到字符串中相同的大写字母,并将其转化为对应的星期和时间。代码示例展示了如何处理这种情况,包括查找相同的字母,转换为数字,并输出正确的日期和时间格式。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

PAT1014 福尔摩斯的约会

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

我们约会吧!
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

题解:
题目中常有将字符转化成整数类型,所以定义字符组的形式用于存储4个字符串,方便实现各种变量之间的相互转换。
将前后四个字符组两两分开,对前两个字符组中注意相同大写字母的出现分情况讨论。后两个字符组相同字母的出现留意。

思路:
1,定义字符组a[61],b[61],c[61],d[61]存储4个字符串,
2,定义day[7][5]用于储存星期,方便后面实现变量之间的星湖转换。
3,利用循环语句找出第一队出现相同的字母,将字符转换成数值形式(最后转成day形式),第二对相同字母直接按输出格式要求将字母转换成数值形式。表示小时。
4,后两个字符组相同字符出现的时候,记录下出现位置i(c[i]=d[i]),i表示分钟
5,将星期,小时,分钟按输出格式输出。

注意:
1,小时与分钟的输出格式要求是2位整数。防止出现答案错误。
2,对小时的判断要找对位置,是第二对相同字母。

代码:

#include<cstdio>
#include<iostream>
using namespace std;
int main(){
	char a[61],b[61],c[61],d[61];     //定义4个字符组用于储存
	cin>>a>>b>>c>>d;
	char day[7][5]={"MON","TUE","WED","THU","FRI","SAT","SUN"};   //将星期的输出格式直接储存起来,方便后面输出。
	int i,j,k;
	int n,h,m;
	for(i=0,j=0;a[i]!='\0';i++){     //对前两组字符组讨论
		if(a[i]==b[i]){
			if(j==0){
				if(a[i]>='A'&&a[i]<='G'){     //找出满足条件的第一对字母
					n=a[i]-'A';
					j++;
					continue;
				}
			}
			else {       //第二对字母,分情况讨论
				if(a[i]>='A'&&a[i]<='N'){    
					h=a[i]-'A'+10;
					break;
				}
				if(a[i]>='0'&&a[i]<='9'){
					h=a[i]-'0';
					break;
				}
			}
		}
	}
	for(i=0;c[i]!='\0';i++){
		if((c[i]>='A'&&c[i]<='Z')||(c[i]>='a'&&c[i]<='z')){   //按条件找出第三对字母
			if(c[i]==d[i])
				m=i;
		}
	}
	printf ("%s %02d:%02d",day[n],h,m);    //将得到各组数据按输出格式输出。
	return 0;
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值