PAT_Basic 1014
2016-03-07 15:03
423 查看
Need to get the information about ASCLL
/*
大侦探福尔摩斯接到一张奇怪的字条:“我们约会吧! 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
*/
#include <string>
#include <iostream>
#include <vector>
using namespace std;
void main(){
string input[4];
for (int i = 0; i < 4; i++)
cin >> input[i];
string DAY[7];
for (int i = 0; i < 7; i++){
switch (i)
{
case 0: DAY[i] = "MON"; break;
case 1: DAY[i] = "TUE"; break;
case 2: DAY[i] = "WED"; break;
case 3: DAY[i] = "THU"; break;
case 4: DAY[i] = "FRI"; break;
case 5: DAY[i] = "SAT"; break;
case 6: DAY[i] = "SUN"; break;
default:
break;
}
}
int ans1, ans2,ans3;
int label12 = 0;
for (int i = 0; i < input[0].size(); i++){
int tmp1 = input[0][i] - 'A';
int tmp2 = input[1][i] - 'A';
if (tmp1 != tmp2) continue;
if (tmp1 >= 0 && tmp1 <= 25){
label12++;
}
if (label12 == 1)
ans1 = tmp1;
else if (label12 == 2)
ans2 = tmp1;
}
label12 = 0;
for (int i = 0; i < input[2].size(); i++){
int tmp3 = input[2][i] - 'A';
int tmp4 = input[3][i] - 'A';
if (tmp3 != tmp4) continue;
if ((tmp3 >= 0 && tmp3 <= 25) || (tmp3 >= 32 && tmp3 <= 57)){
label12++;
}
if (label12 == 1)
ans3 = i;
}
cout << DAY[ans1] << " " << ans2 + 10 <<" : "<< ans3;
system("pause");
}
/*
大侦探福尔摩斯接到一张奇怪的字条:“我们约会吧! 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
*/
#include <string>
#include <iostream>
#include <vector>
using namespace std;
void main(){
string input[4];
for (int i = 0; i < 4; i++)
cin >> input[i];
string DAY[7];
for (int i = 0; i < 7; i++){
switch (i)
{
case 0: DAY[i] = "MON"; break;
case 1: DAY[i] = "TUE"; break;
case 2: DAY[i] = "WED"; break;
case 3: DAY[i] = "THU"; break;
case 4: DAY[i] = "FRI"; break;
case 5: DAY[i] = "SAT"; break;
case 6: DAY[i] = "SUN"; break;
default:
break;
}
}
int ans1, ans2,ans3;
int label12 = 0;
for (int i = 0; i < input[0].size(); i++){
int tmp1 = input[0][i] - 'A';
int tmp2 = input[1][i] - 'A';
if (tmp1 != tmp2) continue;
if (tmp1 >= 0 && tmp1 <= 25){
label12++;
}
if (label12 == 1)
ans1 = tmp1;
else if (label12 == 2)
ans2 = tmp1;
}
label12 = 0;
for (int i = 0; i < input[2].size(); i++){
int tmp3 = input[2][i] - 'A';
int tmp4 = input[3][i] - 'A';
if (tmp3 != tmp4) continue;
if ((tmp3 >= 0 && tmp3 <= 25) || (tmp3 >= 32 && tmp3 <= 57)){
label12++;
}
if (label12 == 1)
ans3 = i;
}
cout << DAY[ans1] << " " << ans2 + 10 <<" : "<< ans3;
system("pause");
}
相关文章推荐
- android 上传文件到服务器代码实例
- workqueque 使用例子
- 自动化测试用例编写守则
- 九章算法4:动态规划I
- Activity的启动模式
- 键盘模式 汉字
- 谢谢CSDN让我的BLOG可以重新使用了
- spyder使用教程
- 413 Request Entity Too Large错误解决办法
- C语言快速排序模板大全(qsort函数)
- CSS盒模型
- Struts2的类型转换及输入校验(数组类型的使用)
- 学习进度总结
- Apache与Nginx服务器对比
- bzoj1008[简单组合数学]
- centos挂载NTFS移动硬盘
- crontab文件的含义
- ios 的 字段、方法、属性的访问权限控制
- 属性的校验
- Arcgis for android 离线查询