吉大秦少游 2018-11-21 14:25 采纳率: 0%
浏览 1160

1014 福尔摩斯的约会,测试案例4提示Segmentation Fault,找不出错误~,求助!

1014 福尔摩斯的约会 (20 point(s))

大侦探福尔摩斯接到一张奇怪的字条:我们约会吧! 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

 #include <iostream>
#include <string>
using namespace std;

int main(){
    string s1,s2,s3,s4; cin>>s1>>s2>>s3>>s4;
    int f1=0,f2=0;
    string week[7]={"MON","TUE","WED","THU","FRI","SAT","SUN"};
    for(int i=0;i<s1.length() ;i++){
        if(s1[i]==s2[i]&&(s1[i]-'A'>=0&&s1[i]-'A'<=25)&&f1==0){ //s1,s2字符串中相等的字符且是大写字母 
            cout<<week[s1[i]-65]<<" ";
            f1=1;
            i++;
        }
        if(s1[i]==s2[i]&&f1==1){    //钟点 
            if(s1[i]-'0'>=0&&s1[i]-'0'<=9){
                printf("%02d:",s1[i]-'0');
                break;
            }
            if(s1[i]-'A'>=0&&s1[i]-'A'<=13){
                printf("%02d:",s1[i]-'A'+10);
                break;
            }
        }   
    }
    for(int i=0;i<s3.length() ;i++){    //分钟 
        if(s3[i]==s4[i]&&isalpha(s3[i])){
            printf("%02d",i);
            break;
        }   
    }
    return 0;
} 

  • 写回答

1条回答 默认 最新

  • return_failed 2018-11-22 00:53
    关注

    没问题啊,有结果的:THU 14:04

     #include "stdafx.h"
    #include <iostream>
    #include <string>
    using namespace std;
    
    int main()
    {
        string s1,s2,s3,s4; cin>>s1>>s2>>s3>>s4;
        int f1=0,f2=0;
        string week[7]={"MON","TUE","WED","THU","FRI","SAT","SUN"};
        for(int i=0;i<s1.length() ;i++)
        {
            if(s1[i]==s2[i]&&(s1[i]-'A'>=0&&s1[i]-'A'<=25)&&f1==0)
            { //s1,s2字符串中相等的字符且是大写字母 
                cout<<week[s1[i]-65]<<" ";
                f1=1;
                i++;
            }
            if(s1[i]==s2[i]&&f1==1)
            {    //钟点 
                if(s1[i]-'0'>=0&&s1[i]-'0'<=9)
                {
                    printf("%02d:",s1[i]-'0');
                    break;
                }
                if(s1[i]-'A'>=0&&s1[i]-'A'<=13)
                {
                    printf("%02d:",s1[i]-'A'+10);
                    break;
                }
            }   
        }
        for(int i=0;i<s3.length() ;i++)
        {    //分钟 
            if(s3[i]==s4[i]&&isalpha(s3[i]))
            {
                printf("%02d",i);
                break;
            }   
        }
        return 0;
    } 
    
    评论

报告相同问题?

悬赏问题

  • ¥15 如何让企业微信机器人实现消息汇总整合
  • ¥50 关于#ui#的问题:做yolov8的ui界面出现的问题
  • ¥15 如何用Python爬取各高校教师公开的教育和工作经历
  • ¥15 TLE9879QXA40 电机驱动
  • ¥20 对于工程问题的非线性数学模型进行线性化
  • ¥15 Mirare PLUS 进行密钥认证?(详解)
  • ¥15 物体双站RCS和其组成阵列后的双站RCS关系验证
  • ¥20 想用ollama做一个自己的AI数据库
  • ¥15 关于qualoth编辑及缝合服装领子的问题解决方案探寻
  • ¥15 请问怎么才能复现这样的图呀