【算法笔记】B1014 福尔摩斯的约会
大侦探福尔摩斯接到一张奇怪的字条:我们约会吧! 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
分析:
本题不算太难,只是细节比较多容易出错。
- 首先这里的相同是指字符相同,位置对应;
- 星期的条件是前两个字符串的第一对相同的大写字母;
- 小时的条件是前两个字符串的第二对相同的字符,这里的字符是指数字0-9和字母A-N;
- 分钟的条件是后两个字符串的第一对相同的不区分大小写的字母的位置,出现在第几个位置就是几分钟;
- 小时和分钟输出时注意,数值小于10,要在前面加个0;
CODE:
#include<iostream>
#include<string>
using namespace std;
void Week(int n)
{
switch(n)
{
case :cout<<"MON"<<' ';break;
case :cout<<"TUE"<<' ';break;
case :cout<<"WED"<<' ';break;
case :cout<<"THU"<<' ';break;
case :cout<<"FRI"<<' ';break;
case :cout<<"SAT"<<' ';break;
case :cout<<"SUN"<<' ';break;
}
}
int main()
{
string a,b,c,d;
cin>>a>>b>>c>>d;
int i=;
bool flag=false;
while(i<a.length()&&i<b.length())
{
if(a[i]==b[i])
{
if(flag)
{
if(a[i]>=''&&a[i]<='')
{
cout<<<<a[i]-''<<':';
break;
}
else if(a[i]>='A'&&a[i]<='N')
{
int n=a[i]-'A'+;
cout<<n+<<':';break;
}
}
if(!flag&&a[i]>='A'&&a[i]<='G')
{
int n=a[i]-'A'+;
Week(n);
flag=true;
}
}
i++;
}
i=;
while(i<c.length()&&i<d.length())
{
if(c[i]==d[i]&&(c[i]>='A'&&c[i]<='Z'||c[i]>='a'&&c[i]<='z'))
{
if(i<)
cout<<;
cout<<i;
break;
}
i++;
}
return ;
}
我不知道为什么,用函数写的一样的代码,总是有几个测试点出错- -
错误代码:
#include<iostream>
#include<string>
using namespace std;
void Week(int n){
switch(n){
case 0: cout<<"MON "; break;
case 1: cout<<"TUE "; break;
case 2: cout<<"WED "; break;
case 3: cout<<"THU "; break;
case 4: cout<<"FRI "; break;
case 5: cout<<"SAT "; break;
case 6: cout<<"SUN "; break;
}
} void D_H(string a,string b){
int i=0;
bool flag=false;
while(i<a.length()&&i<b.length())
{
if(a[i]==b[i])
{
if(flag)
{
if(a[i]>='0'&&a[i]<='9')
{
cout<<0<<a[i]<<':';
break;
}
else if(a[i]>='A'&&a[i]<='N')
{
int n=a[i]-'A'+1;
cout<<n+9<<':';break;
}
}
if(!flag&&a[i]>='A'&&a[i]<='G')
{
int n=a[i]-'A';
Week(n);
flag=true;
}
}
i++;
}
}
void Min(string a,string b){
int i=0;
while(i<a.length()&&i<b.length())
{
if(a[i]==b[i]&&(a[i]>='A'&&a[i]<='Z'||a[i]>='a'&&a[i]<='z'))
{
if(i<10)
cout<<0;
cout<<i;
break;
}
i++;
}
} int main(){
string a,b,c,d;
cin>>a>>b>>c>>d;
D_H(a,b);
Min(a,b);
return 0;
}
【算法笔记】B1014 福尔摩斯的约会的更多相关文章
- 【PAT】B1014 福尔摩斯的约会
因为前面两字符串中第 1 对相同的大写英文字母(大小写有区分)是第 4 个字母D,代表星期四: 第 2 对相同的字符是 E ,那是第 5 个英文字母,代表一天里的第 14 个钟头(于是一天的 0 点到 ...
- B1014. 福尔摩斯的约会
14/20 #include<bits/stdc++.h> using namespace std; map<char,string> day; int main(){ day ...
- kNN算法笔记
kNN算法笔记 标签(空格分隔): 机器学习 kNN是什么 kNN算法是k-NearestNeighbor算法,也就是k邻近算法.是监督学习的一种.所谓监督学习就是有训练数据,训练数据有label标好 ...
- PAT乙级 1014. 福尔摩斯的约会 (20)
1014. 福尔摩斯的约会 (20) 时间限制 100 ms 内存限制 65536 kB 代码长度限制 8000 B 判题程序 Standard 作者 CHEN, Yue 大侦探福尔摩斯接到一张奇怪的 ...
- PAT-乙级-1014. 福尔摩斯的约会 (20)
1014. 福尔摩斯的约会 (20) 时间限制 100 ms 内存限制 65536 kB 代码长度限制 8000 B 判题程序 Standard 作者 CHEN, Yue 大侦探福尔摩斯接到一张奇怪的 ...
- 浙江大学PAT上机题解析之1014. 福尔摩斯的约会 (20)
1014. 福尔摩斯的约会 (20) 时间限制 50 ms 内存限制 32000 kB 代码长度限制 8000 B 判题程序 Standard 作者 CHEN, Y ...
- 学习Java 以及对几大基本排序算法(对算法笔记书的研究)的一些学习总结(Java对算法的实现持续更新中)
Java排序一,冒泡排序! 刚刚开始学习Java,但是比较有兴趣研究算法.最近看了一本算法笔记,刚开始只是打算随便看看,但是发现这本书非常不错,尤其是对排序算法,以及哈希函数的一些解释,让我非常的感兴 ...
- PAT 乙级 1014 福尔摩斯的约会 (20) C++版
1014. 福尔摩斯的约会 (20) 时间限制 100 ms 内存限制 65536 kB 代码长度限制 8000 B 判题程序 Standard 作者 CHEN, Yue 大侦探福尔摩斯接到一张奇怪的 ...
- PAT 1014 福尔摩斯的约会 (20)(代码+思路)
1014 福尔摩斯的约会 (20)(20 分) 大侦探福尔摩斯接到一张奇怪的字条:"我们约会吧! 3485djDkxh4hhGE 2984akDfkkkkggEdsb s&hgsfd ...
随机推荐
- c++ list 容器
List vector在STL中是一个双向链表,它的内部结构和vector 或 deque截然不同.主要有以下几点: 1.List不支持随机存取.list没有提供下标操作符和at()的访问. 2.任何 ...
- 2-python代码坑点
#切片: # L = ['aaa', 'bbb', 'ccc', 'ddd'] # print(L[1 : 3]) #取[1, 3):下标 # L = list(range(100)) # print ...
- 面试题:java实例变量,局部变量,类变量 背1
一.实例变量 也叫对象变量.类成员变量:从属于类由类生成对象时,才分配存储空间,各对象间的实例变量互不干扰,能通过对象的引用来访问实例变量.但在Java多线程中,实例变量是多个线程共享资源,要注意同步 ...
- Log4J 配置 详解
Log4J的配置文件(Configuration File)就是用来设置记录器的级别.存放器和布局的,它可接key=value格式的设置或xml格式的设置信息.通过配置,可以创建出Log4J的运行环境 ...
- JMS-消息中间件的应用01-基本概念-来自慕课学习-新手学习
什么是JMS? Java消息服务(Java Message Service),即JMS,是一个java平台中关于面向消息中间件的API,用于在两个应用程序之间,或分布式系统中发送消息,进行异步通信. ...
- Oracle数据库管理
一.Oracle 的(资源限制)概要文件 为了控制系统资源的使用, 可以利用资源限制概要文件. 资源限制概要文件是 Oracle 安全策略的重要组成部分, 利用资源限制概要文件可以对数据库用户进行基本 ...
- HTML总结之:HTML5的DOCTYPE 与 meta 属性介绍
HTML5头部常用介绍: [DOCTYPE html] 声明文档类型为HTML5文件. [meta标签] <meta> 元素可提供有关页面的元信息(meta-information), ...
- [转]-webkit-overflow-scrolling:touch的应用
-webkit-overflow-scrolling 用来控制元素在移动设备上是否使用滚动回弹效果. 在移动端上,在你用overflow-y:scorll属性的时候,你会发现滚动的效果很木,很慢,这时 ...
- android canvas中rotate()和translate()两个方法详解
rotate()和translate() 1.看到这个题目的时候,有人会觉得这不就是一个对画布的旋转和平移的嘛,但是其中的细节的地方还是需要深究一下的. 例如:有个需求将TextView的文字竖直显示 ...
- IIS部署SSL,.crt .key 的证书,怎么部署到IIS
SSL连接作用不说,百度很多.因为最近想考虑重构一些功能,在登录这块有打算弄成HTTPS的,然后百度了,弄成了,就记录一下,以便以后万一部署的时候忘记掉. 做实验的时候,拿的我个人申请的已经备案的域名 ...