【PAT甲级】1061 Dating (20分)

本文只是本人刷题途中写的小总结用于日后自身复习,如有错误欢迎指出~

题目分析

  1. Sherlock解码破案,从四个字符串中解码得出约会时间。 找出头两个字符串的第一个相同的大写字母(case sensitive)来确定星期几
  2. 找出头两个字符串的继第一个相同大写字母后的相同字符(character:可以是数字也可以是字母)来确定时钟数
  3. 找出后两个字符串的第一个相同的字母(不区分大小写)来确定分钟数

注意点

  1. 大小写不要弄混
  2. 步骤1和2中由于一星期只有七天二十四小时的限制不可以完整的纳入A~Z字母

我的代码

代码思路和debug历程

头两个字符串和后两个字符串分别进行扫描找到需要找出的相同字符。用flag来确定头两个字符串中第一个相同的大写字母有没有被找到。
后来提交有测试点过不了发现是有个if分支里少写了break导致(憨憨如我ヽ(ー_ー)ノ)输出了时钟数还会继续进行循环扫描输出,修改后就通过了。

代码

#include<iostream>
#include<string>

using namespace std;

int main()
{
	string s1, s2, s3, s4;
	string days[] = { "MON","TUE","WED","THU","FRI","SAT","SUN" };
	cin >> s1 >> s2 >> s3 >> s4;
	int length = s1.size() < s2.size() ? s1.size() : s2.size();
	int flag = 0;
	for (int i = 0; i < length; i++) {
		if (s1[i] >= 'A'&&s1[i] <= 'G'&&flag == 0) {//易错点:暗藏第一个相同大写字母必须为A-G
			if (s1[i] == s2[i]) {
				cout << days[s1[i] - 'A'] << ' ';
				flag++;
			}
		}
		else if (s1[i] == s2[i]&& flag != 0) {
			if(s1[i] >= '0'&&s1[i] <= '9'){
				cout << '0' << s1[i] << ':';
				break;//易错点:必须要加break不然容易找到了接着继续找
			}
			else if (s1[i] >= 'A'&&s1[i] <= 'N') {
				cout << s1[i] - 'A' + 10 << ':';
				break;
			}
		}
	}
	length = s3.size() < s4.size() ? s3.size() : s4.size();
	for (int i = 0; i < length; i++) {
		if ((s3[i] >= 'a'&&s3[i] <= 'z') || (s3[i] >= 'A'&&s3[i] <= 'Z')) {
			if (s3[i] == s4[i]) {
				if (i < 10)
					cout << '0' << i;
				else
					cout << i;
			}
		}
	}
    return 0;
}

dalao代码(柳神的)

额因为版权还有格式问题,代码就不全放了,说一些可以借鉴的优美代码点吧~

借鉴点

  1. 采用把i提出来,来实现找出第一个大写字母后接着找相同的字符
  2. 用isdigit()来判断是否是数字0~9
  3. 用isalpha()来判断是否是字母(大写和小写都为true)
  4. 输出的时候采用printf("%02d",mm);可以实现一位数前面0的补全,用printf来输出类似时间之类的又有符号又要补全的还是很方便的~
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值