1014 福尔摩斯的约会 (20 分)

1014 福尔摩斯的约会 (20 分)

大侦探福尔摩斯接到一张奇怪的字条:我们约会吧! 3485djDkxh4hhGE 2984akDfkkkkggEdsb s&hgsfdk d&Hyscvnm。大侦探很快就明白了,字条上奇怪的乱码实际上就是约会的时间星期四 14:04,因为前面两字符串中第 1 对相同的大写英文字母(大小写有区分)是第 4 个字母 D,代表星期四;第 2 对相同的字符是 E ,那是第 5 个英文字母,代表一天里的第 14 个钟头(于是一天的 0 点到 23 点由数字 0 到 9、以及大写字母 AN 表示);后面两字符串第 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个string,for循环比较每一个元素

a1,a2: 第一个相同的大写字母 => 星期几(注意 " : " )

a1,a2: 第二个相同的大写字母 => 几点(0~9 点注意补0)

a3,a4: 第一(二)个相同的字母 => 几分 (注意补0)

 

补救

转换ASCII那里纠结了很久,参考:

https://blog.csdn.net/hy971216/article/details/80527011

才顺利解决

 

尝试AC

(一) 

#include<iostream>
using namespace std;

int main() {
    string a1, a2, a3, a4;
    int i;
    cin>>a1>>a2>>a3>>a4;
    string week[7]= {"MON", "TUE", "WED", "THU", "FRI", "SAT", "SUN"};
    int len1(0), len2(0);
    int flag(0);

    len1=a1.length()>a2.length()?a2.length():a1.length();
    for(i=0; i<len1; i++) {
        // THU
        if(a1[i]==a2[i] && (a1[i]>=65 && a1[i]<=71) && flag==0) {
            flag=1;
            cout<<week[a1[i]-65]<<" ";
            i++;
        }
        //14
        if(flag==1 && a1[i]==a2[i]) {
            if(a1[i]>0 && a1[i]<10) {
                cout<<"0"<<a1[i]-'0'<<":";
                break;
            }

            if(a1[i]>=65 && a1[i]<=71) {
                cout<< 10+(a1[i]-65)<<":";
                break;
            }
        }
    }

    len2=a3.length()>a4.length()?a4.length():a3.length();
    for(i=0; i<len2; i++) {
        // 2 letters
        if(a3[i]==a4[i] && ((a3[i]>='A'&&a3[i]<='Z')||(a3[i]>='a'&&a3[i]<='z')) ) {
            // No. <10
            if(i<10) {
                cout<<0<<i<<endl;
                break;
            }else{
                cout<<i<<endl;
                break;
           }
        }
    }return 0;
}

测试用例过了,但是不知道为什么pta这么狠,只给了我2

再接再厉

 

(二)

line 22 忘记取等号了

然后顺手统一了一下ASCII码,全改成了'A'这种形式

#include<iostream>
using namespace std;

int main() {
    string a1, a2, a3, a4;
    int i;
    cin>>a1>>a2>>a3>>a4;
    string week[7]= {"MON", "TUE", "WED", "THU", "FRI", "SAT", "SUN"};
    int len1(0), len2(0);
    int flag(0);

    len1=a1.length()>a2.length()?a2.length():a1.length();
    for(i=0; i<len1; i++) {
        // THU
        if(a1[i]==a2[i] && (a1[i]>='A' && a1[i]<='Z') && flag==0) {
            flag=1;
            cout<<week[a1[i]-'A']<<" ";
            i++;
        }
        //14
        if(flag==1 && a1[i]==a2[i]) {
            if(a1[i]>=0 && a1[i]<10) {
                cout<<0<<a1[i]-'0'<<":";
                break;
            }

            if(a1[i]>='A' && a1[i]<='N') {
                cout<< 10+(a1[i]-'A')<<":";
                break;
            }
        }
    }

    len2=a3.length()>a4.length()?a4.length():a3.length();
    for(i=0; i<len2; i++) {
        // 2 letters
        if(a3[i]==a4[i] && ((a3[i]>='A'&&a3[i]<='Z')||(a3[i]>='a'&&a3[i]<='z')) ) {
            // No. <10
            if(i<10) {
                cout<<0<<i<<endl;
                break;
            }else{
                cout<<i<<endl;
                break;
           }
        }
    }return 0;
}

 

(三)

改了一下line 22,把0和9 改成了'0' 和 '9'

出现一个段错误

#include<iostream>
using namespace std;

int main() {
    string a1, a2, a3, a4;
    int i;
    cin>>a1>>a2>>a3>>a4;
    string week[7]= {"MON", "TUE", "WED", "THU", "FRI", "SAT", "SUN"};
    int len1(0), len2(0);
    int flag(0);

    len1=a1.length()>a2.length()?a2.length():a1.length();
    for(i=0; i<len1; i++) {
        // THU
        if(a1[i]==a2[i] && (a1[i]>='A' && a1[i]<='Z') && flag==0) {
            flag=1;
            cout<<week[a1[i]-'A']<<" ";
            i++;
        }
        //14
        if(flag==1 && a1[i]==a2[i]) {
            if(a1[i]>='0' && a1[i]<'9') {
                cout<<0<<a1[i]-'0'<<":";
                break;
            }

            if(a1[i]>='A' && a1[i]<='N') {
                cout<< 10+(a1[i]-'A')<<":";
                break;
            }
        }
    }

    len2=a3.length()>a4.length()?a4.length():a3.length();
    for(i=0; i<len2; i++) {
        // 2 letters
        if(a3[i]==a4[i] && ((a3[i]>='A'&&a3[i]<='Z')||(a3[i]>='a'&&a3[i]<='z')) ) {
            // No. <10
            if(i<10) {
                cout<<0<<i<<endl;
                break;
            }else{
                cout<<i<<endl;
                break;
           }
        }
    }return 0;
}

 

(四)

段错误是因为访问了不存在的数组下标

一番查找之后,改了line 15,因为最多到星期天,所以'Z'明显越界

#include<iostream>
using namespace std;

int main() {
    string a1, a2, a3, a4;
    int i;
    cin>>a1>>a2>>a3>>a4;
    string week[7]= {"MON", "TUE", "WED", "THU", "FRI", "SAT", "SUN"};
    int len1(0), len2(0);
    int flag(0);

    len1=a1.length()>a2.length()?a2.length():a1.length();
    for(i=0; i<len1; i++) {
        // THU
        if(a1[i]==a2[i] && (a1[i]>='A' && a1[i]<='G') && flag==0) {
            flag=1;
            cout<<week[a1[i]-'A']<<" ";
            i++;
        }
        //14
        if(flag==1 && a1[i]==a2[i]) {
            if(a1[i]>='0' && a1[i]<='9') {
                cout<<0<<a1[i]-'0'<<":";
                break;
            }

            if(a1[i]>='A' && a1[i]<='N') {
                cout<< 10+(a1[i]-'A')<<":";
                break;
            }
        }
    }

    len2=a3.length()>a4.length()?a4.length():a3.length();
    for(i=0; i<len2; i++) {
        // 2 letters
        if(a3[i]==a4[i] && ((a3[i]>='A'&&a3[i]<='Z')||(a3[i]>='a'&&a3[i]<='z')) ) {
            // No. <10
            if(i<10) {
                cout<<0<<i<<endl;
                break;
            }else{
                cout<<i<<endl;
                break;
           }
        }
    }return 0;
}

 

 

 

 

 

 

 

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值