• 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
    
    分析:代码有错误找不到在哪,用了大佬的部分代码。
    这个题主要是看题,细心最重要。
    DAY是第 1 对相同的大写英文字母,HOUR是第 2 对相同的字符,且必须是数字 0 到 9、以及大写字母 A 到 N;
    MINUTE是后面两字符串第 1 对相同的英文字母,注意是从第4个字符串里找位置,从第三个字符串开始找相同。
     1 #include<iostream>
     2 #include<cstdio>
     3 #include<algorithm>
     4 #include<cstring>
     5 #include<cmath>
     6 using namespace std;
     7 string wk[7]={"MON","TUE","WED","THU","FRI","SAT","SUN"};
     8 int main()
     9 {
    10     string a,b,c,d;
    11     int hs1[1000]={0};
    12     cin>>a>>b>>c>>d;
    13     char x,y;
    14     int n1,n2,n3=0,flag=0,i=0;
    15 //    for(int i=0;i<a.length();i++)
    16 //    {
    17 //        hs1[a[i]]=1;
    18 //    }
    19 //    for(i=0;i<b.length();i++)
    20 //    {
    21 //        if(hs1[b[i]]==1)
    22 //        {
    23 //            if(b[i]>='A'&&b[i]<='G')
    24 //            {
    25 //                x=b[i];
    26 //                break;
    27 //            }
    28 //        }
    29 //    }
    30 //    for(int j=i+1;j<b.length();j++)
    31 //    {
    32 //        if(hs1[b[j]]==1&&((b[j]>='A'&&b[j]<='N')||(b[j]>='0'&&b[j]<='9')))
    33 //        {
    34 //            y=b[j];
    35 //            break;
    36 //        }
    37 //    }
    38 //    n1=x-65;
    39 //    cout<<wk[n1]<<' ';
    40 //    if(y>='A'&&y<='N')
    41 //    {
    42 //        n2=y-55;
    43 //        cout<<n2<<':';
    44 //    }
    45 //    else
    46 //        cout<<'0'<<y-'0'<<':';
    47         int s=a.length()>b.length()?b.length():a.length();
    48         for(int i=0;i<s;i++)
    49         {
    50             if(!flag&&a[i]==b[i]&&(b[i]>='A'&&b[i]<='G'))
    51             {
    52                 flag=1;
    53                 x=b[i];
    54                 continue;
    55             }
    56             if(flag&&a[i]==b[i]&&((b[i]>='A'&&b[i]<='N')||(b[i]>='0'&&b[i]<='9')))
    57             {
    58                 y=b[i];
    59                 break;
    60             }
    61         }
    62         n1=x-65;
    63     cout<<wk[n1]<<' ';
    64     if(y>='A'&&y<='N')
    65     {
    66         n2=y-55;
    67         cout<<n2<<':';
    68     }
    69     else
    70         cout<<'0'<<y<<':';
    71 
    72         int z=c.length()>d.length()?d.length():c.length();
    73         for(int j=0;j<z;j++)
    74         {
    75             if(d[j]==c[j]&&((d[j]>='A'&&d[j]<='Z')||(d[j]>='a'&&d[j]<='z')))
    76             {
    77                 if(j<10)
    78                     cout<<'0'<<j;
    79                 else
    80                     cout<<j;
    81                 break;
    82             }
    83 
    84         }
    85 }
  • 相关阅读:
    《Cracking the Coding Interview》——第12章:测试——题目2
    《Cracking the Coding Interview》——第12章:测试——题目1
    《Cracking the Coding Interview》——第10章:可扩展性和存储空间限制——题目7
    《Cracking the Coding Interview》——第10章:可扩展性和存储空间限制——题目6
    了解/从事机器学习/深度学习系统相关的研究需要什么样的知识结构?
    luoguP1025+codevs 1039 数的划分 x
    luogu P1223 排队接水 x
    luogu P1181 数列分段Section I x
    luogu P2661 信息传递 x
    luoguP1186 玛丽卡 x
  • 原文地址:https://www.cnblogs.com/ygjojo/p/10742302.html
Copyright © 2020-2023  润新知