- 凯撒密码的加密方法:将明文中的每个字母用此字符在字母表中后面的第 k 个字母替代。它的加密过程可以表示为下面的函数:
E(k)=(m+k)modn
其中,m 为明文字母在字母表中的位置数,n 为字母表中的字母个数,k 为密钥,E(k)为密文字母在字母表中对应的位置数。
- 具体代码:
#include<bits/stdc++.h>
using namespace std;
string encrypt(){
vector<char>v(26,0);//字母表
string s;
cout<<"输入需要加密的明文:";
cin>>s;
int k;
cout<<"输入密钥:";
cin>>k;
int j=0;
for(char i='a';i<='z';i++) v[j++]=i;
cout<<"明文:"<<s<<endl;
for(char &c:s){
c=v[(c-'a'+k)%26];
}
cout<<"加密后的密文是:"<<s<<endl;
return s;
}
string decrypt(){
vector<char>v(26,0);//字母表
string s;
cout<<"输入需要解密的明文:";
cin>>s;
int k;
cout<<"输入密钥:";
cin>>k;
int j=0;
for(char i='a';i<='z';i++) v[j++]=i;
cout<<"密文:"<<s<<endl;
for(char &c:s){
if(c-'a'-k%26>0)
c=v[(c-'a'-k%26)%26];
else
c=v[abs(26-abs(c-'a'-k%26))%26];
}
cout<<"解密后的明文是:"<<s<<endl;
return s;
}
int main(){
int n=0;
cout<<"凯撒密码"<<endl;
cout<<"1.加密"<<endl;
cout<<"2.解密"<<endl;
cout<<"3.退出"<<endl;
while(n!=3){
cin>>n;
switch (n)
{
case 1:
encrypt();//加密
cout<<"请继续选择功能"<<endl;
break;
case 2:
decrypt();//解密
cout<<"请继续选择功能"<<endl;
break;
case 3:
n=3;
break;
default:
cout<<"输入错误,请重新输入!"<<endl;
break;
}
}
system("pause");
return 0;
}
整体比较简单,主要代码在加密和解密的字符变换上
本文介绍了凯撒密码的加密原理及其实现代码,通过将明文字母替换为其后的第k个字母进行加密。同时,提供了相应的解密函数,使能对密文进行解密。示例代码展示了如何在C++中使用循环和取模运算完成这一过程。
5707

被折叠的 条评论
为什么被折叠?



