加密算法:
- 生成一个随机数(称作n);(占密码的前三位,统一把每一位加上97)
- 生成和原字符串大小同样多的数字(称作a),为了加密,把数字加上n;(占接下来的几位)
- 在原来每个字符上加上a中对应的值。(占最后几位)
解密算法:
- 分段(前三位一段,后面平均分成两份);
- 根据加密算法反向进行解密。
代码如下:
(加密)
#include<iostream>
#include<string>
#include<cstdlib>
#include<ctime>
using namespace std;
int get_rand(int down,int up){
return rand()%(up-down+1)+down;
}
int main(){
srand(time(NULL));
string s_bef;
getline(cin,s_bef,char(5));
string s_aft;
int num_plus=get_rand(33,117);
s_aft+=(num_plus/100)+97;
s_aft+=(num_plus%100/10)+97;
s_aft+=(num_plus%10)+97;
for(int i=0;i<s_bef.size();++i){
s_aft+=get_rand(0,9)+num_plus;
}
for(int i=0;i<s_bef.size();++i){
s_aft+=s_bef[i]+s_aft[i+3]-num_plus;
}
cout<<s_aft;
return 0;
}
(解密)
#include<iostream>
#include<string>
using namespace std;
int main(){
string s_aft;
getline(cin,s_aft,char(5));
int bef_size=(s_aft.size()-3)>>1;
int num_plus=(s_aft[0]-97)*100+(s_aft[1]-97)*10+(s_aft[2]-97);
string s_bef;
for(int i=bef_size+3;i<s_aft.size();++i){
s_bef+=s_aft[i]-(s_aft[i-bef_size]-num_plus);
}
cout<<s_bef;
return 0;
}
实验过程中,发现一些问题:有时候涉及到换行后面加回车的情况,第一个字符会出错。
有人发现其它的问题请在讨论区中告诉我。
注意:在输入原文本或密码时,最后要加上Ctrl+E再回车,以代表结束。
欢迎转载,但请在文章中附加上本文链接: https://blog.csdn.net/weixin_41461277/article/details/84994552 。