zoukankan      html  css  js  c++  java
  • PAT (Basic Level) Practise (中文)- 1014. 福尔摩斯的约会 (20)

    http://www.patest.cn/contests/pat-b-practise/1014

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

    时间限制
    50 ms
    内存限制
    65536 kB
    代码长度限制
    8000 B
    判题程序
    Standard
    作者
    CHEN, Yue

    大侦探福尔摩斯接到一张奇怪的字条:“我们约会吧! 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
     1 #include<stdio.h>
     2 int main()
     3 {
     4     int weekdays=0,hours=0,mins=0; 
     5     char str1[100],str2[100];
     6     gets(str1);
     7     gets(str2);
     8     
     9     int iStr=0;
    10     while(str1[iStr] && str2[iStr])
    11     {
    12         if(str1[iStr] == str2[iStr] )
    13         {
    14             if( 0==weekdays && 'A'<=str1[iStr] && str1[iStr]<='G')
    15                 weekdays=str1[iStr]-'A'+1;
    16             else if(weekdays)
    17             {
    18                  if('0'<=str1[iStr] && str1[iStr]<='9')
    19                  {
    20                      hours= str1[iStr]-'0';
    21                      break;
    22                  }
    23                  else if('A'<=str1[iStr] && str1[iStr]<='N')
    24                  {
    25                      hours=str1[iStr]-'A'+10;
    26                      break;
    27                  }
    28             }
    29         } 
    30         iStr++;
    31     }
    32     
    33     gets(str1);
    34     gets(str2);
    35     iStr=0;    
    36     while(str1[iStr] && str2[iStr])
    37     {
    38         if(str1[iStr] == str2[iStr] && (('a'<=str1[iStr] && str1[iStr]<='z')||('A'<=str1[iStr] && str1[iStr]<='Z')))
    39         {
    40             mins=iStr;
    41             break;
    42         } 
    43         iStr++;
    44     }
    45     char week[8][5]={"000","MON","TUE","WED","THU","FRI","SAT","SUN"};
    46     printf("%s %02d:%02d",week[weekdays],hours,mins);
    47     return 0;
    48 }
  • 相关阅读:
    jQuery-1.9.1源码分析系列(十六)ajax——ajax框架
    js基础篇——encodeURI 和encodeURIComponent
    apache分析之三、配置文件解析
    apache分析之二、post-commit后台运行
    apache分析之一、svn:Could not open the requested SVN filesystem
    从例子看git的内部实现
    stl中容器的end指向哪里
    使用dependency walker定位windows下程序启动失败原因
    lvs中的保活、persistent及DR
    当磁盘空间满之后,为什么文件依然可以被创建
  • 原文地址:https://www.cnblogs.com/asinlzm/p/4463770.html
Copyright © 2011-2022 走看看