C++加密文本程序

加密算法:

  1. 生成一个随机数(称作n);(占密码的前三位,统一把每一位加上97)
  2. 生成和原字符串大小同样多的数字(称作a),为了加密,把数字加上n;(占接下来的几位)
  3. 在原来每个字符上加上a中对应的值。(占最后几位)

解密算法:

  1. 分段(前三位一段,后面平均分成两份);
  2. 根据加密算法反向进行解密。

代码如下:

(加密)

#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 。

猜你喜欢

转载自blog.csdn.net/weixin_41461277/article/details/84994552