资源限制
时间限制:1.0s 内存限制:256.0MB
问题描述
摩尔斯电码破译。类似于乔林教材第213页的例6.5,要求输入摩尔斯码,返回英文。请不要使用"zylib.h",只能使用标准库函数。用’ * ‘表示’ . ‘,中间空格用’ | '表示,只转化字符表。
摩尔斯码定义见:http://baike.baidu.com/view/84585.htm?fromId=253988。
提示
清橙进行评测时,输入是以EOF结尾的,而不是换行符。(EOF不是一个字符,“以EOF结尾”是一种通俗但不严谨的说法。)因此可以通过以下方式之一获取输入:
1. 一次读入整行字符串,再进行后续解析。
2. 使用getchar或scanf一次读入一个字符,通过它们的返回值判断输入结束。
样例输出
分析‘’
输入一行字符串,检验字符 ‘|’ 的位置,判断应该输出的密码是什么。分为两种情况:第一种只有一个字母,第二种有多个字母。因此,还需对结尾一个字母(或者是只有一个字母时)的情况进行分类讨论。
注意
匹配字母的时候,switch里面是不能使用string类型的参数,如果使用的话,还需要另外配置。
#include<iostream>
using namespace std;
void zhuan(string a)
{
if(a=="*-")
cout<<"a";
else if(a=="-***")
cout<<"b";
else if(a=="-*-*")
cout<<"c";
else if(a=="-**")
cout<<"d";
else if(a=="*")
cout<<"e";
else if(a=="**-*")
cout<<"f";
else if(a=="--*")
cout<<"g";
else if(a=="****")
cout<<"h";
else if(a=="**")
cout<<"i";
else if(a=="*---")
cout<<"j";
else if(a=="-*-")
cout<<"k";
else if(a=="*-**")
cout<<"l";
else if(a=="--")
cout<<"m";
else if(a=="-*")
cout<<"n";
else if(a=="---")
cout<<"o";
else if(a=="*--*")
cout<<"p";
else if(a=="--*-")
cout<<"q";
else if(a=="*-*")
cout<<"r";
else if(a=="***")
cout<<"s";
else if(a=="-")
cout<<"t";
else if(a=="**-")
cout<<"u";
else if(a=="***-")
cout<<"v";
else if(a=="*--")
cout<<"w";
else if(a=="-**-")
cout<<"x";
else if(a=="-*--")
cout<<"y";
else if(a=="--**")
cout<<"z";
}
int main()
{
string s;
int j=-1;
while(cin>>s!=0)
{
int num=s.length();
for(int i=0;i<num;i++)
{
if(s[i]=='|')
{
string as=s.substr(j+1,i-j-1);
zhuan(as);
j=i;
i++;
}
}
string bs=s.substr(j+1,num-1-j);
zhuan(bs);
}
return 0;
}