[PAT乙] 1014. 福尔摩斯的约会 (20)
来源:互联网 发布:网络综艺访谈节目 编辑:程序博客网 时间:2024/05/17 04:01
大侦探福尔摩斯接到一张奇怪的字条:“我们约会吧! 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
此题充分说明,简单的题目也需要审题! countA
此变量什么作用呢?我们知道要寻找第一个相同的大写字母,此时,要确保之后相同的不能被覆盖,所以可以看作一个开关变量,初始置零,找到第一个置非零,用作条件即可。 Switch
也是如此,不过值得一提的是,switch状态改变后,应该continue一下,毕竟寻找的是下一个。
最值得一提的是,题目中隐含的条件。原本我写作这样:
if((isupper(s[i]) && s1[i]==s2[i])
想一想这里怎么不对呢,的确,题目要求找到第一个相同的大写字母。可是隐含的说它是便是星期几的,一次,s[i]
有范围!,盲目使用<cctype> 或 <ctype.h>
极有可能造成一时半会想不到的错误,因此,不如直接借用对数值的控制。
#include <iostream>#include <string>#include <vector>#include <cctype>using namespace std;typedef string::size_type sizet;int main() { string s1, s2, s3, s4; int week, hour, min; vector<string> s{"MON", "TUE", "WED", "THU", "FRI", "SAT", "SUN"}; cin>>s1>>s2>>s3>>s4; int countA = 0, countB=0, Switch =0; for(sizet i=0; i<s1.size() && i<s2.size(); ++i) { if(countA==0) { if((s1[i]>='A' && s1[i]<='G') && s1[i]==s2[i]) { week = (int)(s1[i] - 'A') + 1; countA++; Switch=1; continue; } } if(Switch) { if(s1[i]==s2[i]) { if((s1[i]>='A' && s1[i]<='N') || isdigit(s1[i])) { if(isupper(s1[i])) hour = (int)(s1[i]-'A') + 10; else hour = (int)(s1[i]-'0'); break; } } } } for(sizet i=0; i<s3.size() && i<s4.size(); ++i) { if(isalpha(s3[i]) && s3[i]==s4[i]) { min = i; } } cout << s[week-1] <<' '; printf("%0.2d:%0.2d", hour, min); return 0;}
- [PAT乙] 1014. 福尔摩斯的约会 (20)
- pat 乙 1014. 福尔摩斯的约会
- PAT 1014. 福尔摩斯的约会 (20)
- PAT 1014. 福尔摩斯的约会 (20)
- PAT(B)1014. 福尔摩斯的约会 (20)
- PAT-1014. 福尔摩斯的约会 (20)
- PAT B 1014. 福尔摩斯的约会 (20)
- Java - PAT - 1014. 福尔摩斯的约会 (20)
- 1014. 福尔摩斯的约会 (20) PAT 乙级
- PAT-乙级-1014. 福尔摩斯的约会 (20)
- PAT(B) - 1014. 福尔摩斯的约会 (20)
- PAT(B) 1014. 福尔摩斯的约会 (20)
- PAT.乙级1014. 福尔摩斯的约会 (20)
- PAT-B 1014. 福尔摩斯的约会 (20)
- PAT-B 1014. 福尔摩斯的约会 (20)
- 1014. 福尔摩斯的约会 (20)-PAT乙级
- 1014. 福尔摩斯的约会 (20) PAT
- PAT乙级 1014. 福尔摩斯的约会 (20)
- java访问数据库
- 数据结构循环链表与双链表实验
- linux matlab2016b 安装
- redis 性能相关方面
- 操作系统-PV操作
- [PAT乙] 1014. 福尔摩斯的约会 (20)
- Goroutine的调度分析(二)
- android NDK--C 调用java
- 某集训记录
- 高并发秒杀系统实现和优化分析(行级锁优化和具体过程优化)
- cenos7安装elasticsearch5.5.2
- redis 网络分区
- Mysql课后思考题
- 栈的应用2--通用括号平衡