题解 | #字符串加密#

#include <bits/stdc++.h>

using namespace std;

//encoder
void encoder(string key, string str, string& res){
    //如果单词中包含有重复的字母,只保留第1个,将所得结果作为新字母表开头
    vector<char> s; //s[i]对应的便是26个字母中第i个字母的加密结果
    for(int i = 0; i < key.size(); i++){
        key[i] = tolower(key[i]); //全部转小写
        if(find(s.begin(), s.end(), key[i]) == s.end()) //如果是第一次加入
            s.push_back(key[i]);
    }
    for(char c = 'a'; c <= 'z'; c++){
        if(find(s.begin(), s.end(), c) == s.end()) //如果是第一次加入
            s.push_back(c);
    }
    /*for(char ch : s){
        cout << ch;
    }*/
    
    for(int i = 0; i < str.size(); i++){
        if(isupper(str[i])){
            res += s[str[i] - 'A'] - 32; //需要在转出来的小写字母基础上减32
        }
        else{
            res += s[str[i] - 'a']; //
        }
    }
}

int main(){
    string key = "";
    cin >> key;
    string str = "";
    cin >> str;
    
    string res = "";
    encoder(key, str, res);
    
    cout << res << endl;
    
    return 0;
}

全部评论

相关推荐

AAA专业长城贴瓷砖刘大爷:这样的简历我会直接丢进垃圾桶,花里胡哨的
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客企业服务