字符串加解密
来源:互联网 发布:华为mate8自带软件 编辑:程序博客网 时间:2024/05/21 20:29
题目
2、加密方法为:当内容是英文字母时则用该英文字母的后一个字母替换,同时字母变换大小写,
如字母a时则替换为B;字母Z时则替换为a;
当内容是数字时则把该数字加1,如0替换1,1替换2,9替换0;
其他字符不做变化。
3、解密方法为加密的逆过程。
输入一串加过密的密码 输出 输出加密后的字符
输出解密后的字符 样例输入 abcdefg BCDEFGH 样例输出 BCDEFGH
abcdefg
思路
- 思路一:按照转换关系老老实实的写。。。
- 思路二:建立一个密码表,查表可知加密解密的结果!
代码
#include<iostream>#include<string>using namespace std;void decode(string &str,int length){//解密 for(int i=0;i<length;++i){ if(str[i]>'a'&&str[i]<='z'){ str[i]=(char)(str[i]-31); }else if(str[i]=='a'){ str[i]='Z'; }else if(str[i]>'A'&&str[i]<='Z'){ str[i]=(char)(str[i]+31); }else if(str[i]=='A'){ str[i]='z'; }else if(str[i]>'0'&&str[i]<='9'){ str[i]=(char)(str[i]-1); }else if(str[i]=='0'){ str[i]='9'; } }}void encode(string &str,int length){//加密 for(int i=0;i<length;++i){ if(str[i]>='a'&&str[i]<'z'){ str[i]=(char)(str[i]-31);//33 ‘a’-'A'=32 }else if(str[i]=='z'){ str[i]='A'; }else if(str[i]>='A'&&str[i]<'Z'){ str[i]=(char)(str[i]+31); }else if(str[i]=='Z'){ str[i]='a'; }else if(str[i]>='0'&&str[i]<'9'){ str[i]=(char)(str[i]+1); }else if(str[i]=='9'){ str[i]='0'; } }}int main(){ string temp=""; //1------ cin>>temp; encode(temp,temp.length()); cout<<temp<<endl; //2----- cin>>temp; decode(temp,temp.length()); cout<<temp<<endl; return 0;}
0 0
- 字符串的加解密
- 字符串加解密
- 字符串加解密
- php字符串加解密
- 字符串加解密
- 字符串加解密
- 字符串加解密
- 字符串加解密
- 字符串加解密
- 字符串加解密
- 字符串加解密
- 字符串加解密
- 字符串加解密
- 字符串加解密
- 字符串加解密 算法
- 字符串加解密
- 字符串加解密
- 字符串加解密
- 【Unity&DragonBone】为什么我从DragonBone导入Unity没有图片
- iar中使用DMA+printf+uart1
- Win7环境Word 2013编辑文档慢、卡顿的解决方法
- ERP实施顾问工作中应努力做到哪些?
- iOS Https协议 自签证书访问数据
- 字符串加解密
- hdu 1828 Picture(线段树,扫描线之周长并)
- Spring的BeanFactoryPostProcessor和BeanPostProcessor
- MyBatis如何禁用掉一级缓存。
- synchronized
- js错误捕获
- python根据类名映射
- java.util.vector中的vector的详细用法
- BeanFactoryPostProcessor和BeanPostProcessor的区别