题解 | 字符串加解密

字符串加解密

https://www.nowcoder.com/practice/2aa32b378a024755a3f251e75cbf233a

#include <iostream>
#include <cctype>
using namespace std;

char alpha_trans(char c, bool decode) {
    char ans;
    if(isupper(c)) {
        int n = (c - 'A');
        if(!decode) n = (n + 1) % 26; //加密
        else n = (n + 25) % 26; //解密
        ans = n + 'A';
        ans = tolower(ans);
    } else {
        int n = (c - 'a');
        if(!decode) n = (n + 1) % 26; //加密
        else n = (n + 25) % 26; //解密
        ans = n + 'a';
        ans = toupper(ans);
    }
    return ans;
}

char num_trans(char c, bool decode) {
    int n = c - '0';
    if(decode) { //解密
        n = (n + 9) % 10;
    } else { //加密
        n = (n + 1) % 10;
    }
    c = '0' + n;
    return c;
}

int main() {
    string s, t;
    cin >> s >> t;
    string encrypt, decode;
    for(const char& c: s) { //对s加密
        if(isalpha(c)) {
            encrypt += alpha_trans(c, false);
        } else {
            encrypt += num_trans(c, false);
        }
    }
    for(const char& c: t) { //对t解密
        if(isalpha(c)) {
            decode += alpha_trans(c, true);
        } else {
            decode += num_trans(c, true);
        }
    }
    cout << encrypt << endl;
    cout << decode << endl;
    return 0;
}

全部评论

相关推荐

神哥不得了:神哥来啦~1.建议不要包装,很容易问穿2.没日常也能找到暑期3.简历模板换一下,字体和版式看着好难受,而且最好压缩到一页,技术的倒数第2和3重复啦,项目建议换两个高质量的上去,如果时间够的话,八股就把高频top50的题目多巩固几遍,吃透,注意不要找假高频,这样绝对能找到暑期
点赞 评论 收藏
分享
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客企业服务