码迷,mamicode.com
首页 > 其他好文 > 详细

福尔摩斯的约会 (20)

时间:2017-04-14 19:51:36      阅读:244      评论:0      收藏:0      [点我收藏+]

标签:getch   思路   else   turn   实现   区分   输出   表示   帮助   

福尔摩斯的约会 (20)

时间限制 1000 ms 内存限制 32768 KB 代码长度限制 100 KB

题目描述

大侦探福尔摩斯接到一张奇怪的字条:“我们约会吧! 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、字符串存储、判断。
v1版用了四个字符串,也可以用二维数组实现。
2、字符串比较
细心!细心!细心!
第一项 周几 前两个字符串中第一对相同的大写字母
第二项 时 前两个字符串中第二对相同的0~9或A~N
第三项 分 后两个字符串中第一对相同的英文字母(可以是大写也可以是小写)

注意输出格式。

看过大神贴的代码,简洁清爽。V1版仍然略显拖沓,但思路清晰,可用以参考。

v1版↓
 1 #include<stdio.h>
 2 
 3 int main(){
 4     char a[60]={\0},b[60]={\0},c[60]={\0},d[60]={\0};
 5     char ch;
 6     int i,al=0,bl=0,cl=0,dl=0,l,day,hour;
 7      
 8     ch=getchar();
 9     for(i=0;ch!=\n&&i<60;i++){
10         a[i]=ch;
11         ch=getchar();
12         al++;
13     }
14     a[i]= ;
15     ch=getchar();
16     for(i=0;ch!=\n&&i<60;i++){
17         b[i]=ch;
18         ch=getchar();
19         bl++;
20     }
21     b[i]= ;
22     ch=getchar();
23     for(i=0;ch!=\n&&i<60;i++){
24         c[i]=ch;
25         ch=getchar();
26         cl++;
27     }
28     d[i]= ;
29     ch=getchar();
30     for(i=0;ch!=\n&&i<60;i++){
31         d[i]=ch;
32         ch=getchar();
33         dl++;
34     }
35     a[i]= ;
36     
37     l=al>bl?bl:al;
38     for(i=0;i<l;i++){//周几 
39         if(a[i]==b[i]&&a[i]>=A&&a[i]<=G){
40             day=(int)(a[i]-(A-1));
41             break;
42         }
43     }
44     for(i++;i<l;i++){//几点 
45         if(a[i]==b[i]&&a[i]>=0&&a[i]<=9){
46             hour=(int)(a[i]-0);
47             break;
48         }
49         if(a[i]==b[i]&&a[i]>=A&&a[i]<=N){
50             hour=(int)(a[i]-A+10);
51             break;
52         }
53     }
54     
55     l=cl>dl?dl:cl;
56     for(i=0;i<l;i++){
57         if(c[i]==d[i]&&((c[i]>=A&&c[i]<=Z)||(c[i]>=a&&c[i]<=z))){
58             break;
59         }
60     }
61     
62     switch(day){
63     case 1:printf("MON ");break;
64     case 2:printf("TUE ");break;
65     case 3:printf("WED ");break;
66     case 4:printf("THU ");break;
67     case 5:printf("FRI ");break;
68     case 6:printf("SAT ");break;
69     case 7:printf("SUN ");break;
70     }
71     
72     if(hour<10)
73         printf("0%d:",hour);
74     else
75         printf("%d:",hour);
76     
77     if(i<10)
78         printf("0%d",i);
79     else
80         printf("%d",i);
81 
82     return 0;
83 }

 




福尔摩斯的约会 (20)

标签:getch   思路   else   turn   实现   区分   输出   表示   帮助   

原文地址:http://www.cnblogs.com/AndKuang17/p/6710273.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!