Description
在大学里,很多单词都是一词多义,偶尔在文章里还要用引申义。这困扰Redraiment很长的时间。
他开始搜集那些单词的所有意义。他发现了一些规律,例如
“a”能用“e”来代替, “c”能用“f”来代替……
现在他给出了字母的替换规则,如下所示,A被E替换,B被C替换,依次类推。
A B C D E F G H I J K L M N O P Q R S T U V W X Y Z
E C F A J K L B D G H I V W Z Y M N O P Q R S T U X
a b c d e f g h i j k l m n o p q r s t u v w x y z
e r w q t y g h b n u i o p s j k d l f a z x c v m
Input
本题包括多组测试数据。
每组测试数据为一行:为仅由字母和空格组成的字符串(空格不变),长度不超过1000个字符。
输入以单行“#”结束。
Output
对应每组测试数据,替换后输出它的引申义。
Sample Input
Ilttabaje zaujljg
#
Sample Output
Different meaning
#include <iostream>
#include <conio.h>
#include <string>
using namespace std;
int main( void )
{
string arraya;
char arrayb[ 1001 ];
int i;
char a[ 2 ][ 27 ]=
{
"ECFAJKLBDGHIVWZYMNOPQRSTUX",
"erwqtyghbnuiopsjkdlfazxcvm"
};
while( 1 )
{
getline(cin, arraya );
if( arraya[ 0 ]== '#' )
{
break;
}
for( i= 0; i< arraya.size(); i++ )
{
if( arraya[ i ]>= 'A' && arraya[ i ]<= 'Z' )
{
arrayb[ i ]= a[ 0 ][ arraya[ i ]- 65 ];
}
else if( arraya[ i ]>= 'a' && arraya[ i ]<= 'z' )
{
arrayb[ i ]= a[ 1 ][ arraya[ i ]- 97 ];
}
else
{
arrayb[ i ]= arraya[ i ];
}
}
arrayb[ i ]= '\0';
cout<< arrayb<< endl;
}
return 0;
}