凯撒密码C++

Julius Caesar 生活在充满危险和阴谋的年代。为了生存,他首次发明了密码,用于军队的消息传递。
假设你是Caesar 军团中的一名军官,需要把Caesar 发送的消息破译出来、并提供给你的将军。
消息加密的办法是:对消息原文中的每个字母,分别用该字母之后的第5个字母替换(
例如:消息原文中的每个字母A都分别替换成字母F),其他字符不 变,并且消息原文的所有字母都是大写的。
 输入 密码字母: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 
 输出 原文字母:V W X Y Z A B C D E F G H I J K L M N O P Q R S T U
输入
最多不超过100个数据集组成。每个数据集由3部分组成:起始行:START 密码消息:由1到200个字符组成一行,
表示Caesar发出的一条消息结束行:END 在最后一个数据集之后,是另一行:ENDOFINPUT
输出
每个数据集对应一行,是Caesar 的原始消息。

 

#include<iostream>
using namespace std;

int main(){
	string sign="ENDOFINPUT";
    string a,b;
    string word;
	while(cin>>a&&a!=sign){
		cin.get();
		getline(cin,word);
		for(int i=0;i<word.size();i++){
			if(word[i]>='A'&&word[i]<='Z'){
				if(word[i]>='F'&&word[i]<='Z')
				   word[i]=word[i]-5;
				else if(word[i]=='A')
				   word[i]='V'; 
				else if(word[i]=='B')
				   word[i]='W';   
				else if(word[i]=='C')
				   word[i]='X';  
				else if(word[i]=='D')
				   word[i]='Y';  
				else if(word[i]=='E')
				   word[i]='Z';  
			} 
			else 
			    word[i]=word[i]; 
		}
		cin>>b;
	    cout<<word<<endl; 
	}
	return 0;
}

猜你喜欢

转载自blog.csdn.net/Fragrance152/article/details/81394272