zoukankan      html  css  js  c++  java
  • 1014. 福尔摩斯的约会 (20)

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

    时间限制
    100 ms
    内存限制
    65536 kB

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

    注意:注意红字部分,原题描述的不是特别清楚。
     1 #include <bits/stdc++.h>
     2 using namespace std;
     3 
     4 int main()
     5 {
     6     const char* week[]={" ","MON","TUE","WED","THU","FRI","SAT","SUN"};
     7     string s1,s2,s3,s4;
     8     cin>>s1>>s2>>s3>>s4;
     9     int flag=1;
    10     for(int i=0;flag<3;i++){
    11         if(s1[i]==s2[i]){
    12             if(flag==1&&isupper(s1[i])&&s1[i]<'H'){
    13                 cout<<week[s1[i]-'A'+1]<<" ";
    14                 flag++;
    15             }
    16             else if(flag==2){
    17                 if(isdigit(s1[i])){
    18                     cout<<'0'<<s1[i]<<":";
    19                     flag++;
    20                 }
    21                 else if(isupper(s1[i])&&s1[i]<='N'){
    22                     cout<<(10+s1[i]-'A')<<":";
    23                     flag++;
    24                 }
    25             }
    26         }
    27     }
    28     for(int i=0;1;i++){
    29         if(s3[i]==s4[i]&&isalpha(s3[i])){
    30             cout<<setw(2)<<setfill('0')<<i<<endl;
    31             break;
    32         }
    33     }
    34     return 0;    
    35 }
     
  • 相关阅读:
    2020牛客寒假算法基础集训营4-I 匹配星星【贪心】
    P1880 [NOI1995]石子合并【区间dp】
    P1280 尼克的任务
    P1041 传染病控制【暴搜】
    Heavy Transportation POJ
    【空间】C++内存管理
    【编译器】G++常用命令
    【NOIP2011】【Luogu1003】铺地毯
    【Luogu1739】表达式括号匹配
    【Luogu1160】队列安排
  • 原文地址:https://www.cnblogs.com/Fresh--air/p/8576650.html
Copyright © 2011-2022 走看看