题解 | 字符串加密

字符串加密

https://www.nowcoder.com/practice/e4af1fe682b54459b2a211df91a91cf3

#include <iostream>
#include <string>
#include <map>
#include <set>

using namespace std;

map<char, char> m;
string pat = "abcdefghijklmnopqrstuvwxyz";
void init(string s) {
    set<char> isexist;
    string p;
    for (auto elem : s) {
        if (isexist.count(elem) == 0) {
            p += elem;
            isexist.insert(elem);
        }
    }
    // 补齐p
    for (auto elem : pat) {
        if (isexist.count(elem) == 0) {
            p += elem;
            isexist.insert(elem);
        }
    }
    // 生成映射
    char ch = 'a';
    for (auto elem : p) {
        m[ch++] = elem;
    }
}

int main() {
    string str;
    cin >> str;
    init(str); // 根据str计算出模式串p,然后再得到映射关系的map
    string res;
    cin >> res;
    for (auto& elem : res) {
        elem = m[elem];
    }
    cout << res << endl;

    return 0;
}

全部评论

相关推荐

迷茫的大四🐶:都收获五个了,兄弟那还说啥,不用改了,去玩吧
点赞 评论 收藏
分享
牛客96763241...:杭电✌️也是打完招呼,没人回吗
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务