HJ29 字符串加解密
生活随笔
收集整理的這篇文章主要介紹了
HJ29 字符串加解密
小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.
描述
1、對(duì)輸入的字符串進(jìn)行加解密,并輸出。
2、加密方法為:
當(dāng)內(nèi)容是英文字母時(shí)則用該英文字母的后一個(gè)字母替換,同時(shí)字母變換大小寫(xiě),如字母a時(shí)則替換為B;字母Z時(shí)則替換為a;
當(dāng)內(nèi)容是數(shù)字時(shí)則把該數(shù)字加1,如0替換1,1替換2,9替換0;
其他字符不做變化。
3、解密方法為加密的逆過(guò)程。
本題含有多組樣例輸入。
輸入描述:
輸入說(shuō)明
輸入一串要加密的密碼
輸入一串加過(guò)密的密碼
輸出描述:
輸出說(shuō)明
輸出加密后的字符
輸出解密后的字符
思路一:
常規(guī)思路,一個(gè)個(gè)判斷
#include <iostream> #include <string> using namespace std; void EnCode(string str){string restult;for(int i=0;i<str.size();i++){//先處理小寫(xiě)字母if(str[i]>='a'&&str[i]<='z'){if(str[i]=='z'){restult += 'A';}else {restult += str[i]-32+1; //小數(shù)變大并后移一位 }}else if(str[i]>='A'&&str[i]<='Z'){ //再處理大寫(xiě)字母if(str[i]=='Z'){restult+='a';}else {restult += str[i]+32+1; //大數(shù)變小數(shù)并前移一位 }}else if(str[i]>='0'&&str[i]<='9'){if(str[i]=='9'){restult+='0';}else {restult += str[i]+1;}}}cout << restult<<endl; }void DeCode(string str){string restult;for(int i=0;i<str.size();i++){//先處理小寫(xiě)字母if(str[i]>='a'&&str[i]<='z'){if(str[i]=='a'){restult += 'Z';}else {restult += toupper(str[i])-1; //解密先變大后減去1}}else if(str[i]>='A'&&str[i]<='Z'){ //再處理大寫(xiě)字母if(str[i]=='A'){restult+='z';}else {restult += tolower(str[i]) - 1 ; }}else if(str[i]>='0'&&str[i]<='9'){if(str[i]=='0'){restult+='9';}else {restult += str[i]-1;}}}cout << restult<<endl; }int main(){string str1,str2; //輸入字符串while(cin>>str1>>str2){EnCode(str1);DeCode(str2);}return 0; }總結(jié)
以上是生活随笔為你收集整理的HJ29 字符串加解密的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
- 上一篇: c++常见的排序表与复杂度
- 下一篇: 力扣(leetcode)-1. 两数之和