字符串加解密

字符串加解密

http://www.nowcoder.com/questionTerminal/2aa32b378a024755a3f251e75cbf233a

存粹考代码

思路:

  1. 建立两个容器,加密字母大小变换后推,数字后推,其他不变
  2. 解密字母大小变换前推,数字前推,其他不变
#include<iostream>
#include<string>
#include<vector>
using namespace std;
vector<char> v1;
vector<char> v2;
void EnCode(char ch)
{
    if (ch>= 'a' && ch <= 'z')
    {  
        if (ch == 'z') ch = 'A';
        else
            ch= ch - 31;
    }
    else if (ch >= 'A' && ch <= 'Z')
    {
        if (ch == 'Z') ch = 'a';
        else
            ch = ch +33;
    }
    else if (ch >= '0' && ch <= '9')
    {
        if (ch == '9') ch = '0';
        else
            ch = ch+1;
    }
    v1.push_back(ch);
}
void DeCode(char ch)
{
    if (ch >= 'a' && ch <= 'z')
    {
        if (ch == 'a') ch = 'Z';
        else
            ch = ch - 33;
    }
    else if (ch >= 'A' && ch <= 'Z')
    {
        if (ch =='A') ch = 'z';
        else
            ch = ch + 31;
    }
    else if (ch >= '0' && ch <= '9')
    {
        if (ch == '0') ch = '9';
        else
            ch = ch - 1;
    }
    v2.push_back(ch);
}
int main()
{
    string str1;
    string str2;
    while (getline(cin, str1))
    {
        getline(cin, str2);
        if (str1 == "" || str2 == "") break;
        int len1 = str1.size();
        int len2 = str2.size();
        for (int i = 0; i < len1; i++)
        {
            EnCode(str1[i]);
        }
        for (int i = 0; i < len2; i++)
        {
            DeCode(str2[i]);
        }
        for (int i = 0; i < v1.size(); i++)
            cout << v1[i];
        cout << endl;
        for (int i = 0; i < v2.size(); i++)
            cout << v2[i];
        cout << endl;
        v1.clear();
        v2.clear();
    }
}
全部评论

相关推荐

KPLACE:首先是板面看起来不够,有很多奖,比我厉害。项目要精减,大概详细描述两到三个,要把技术栈写清楚,分点,什么算法,什么外设,怎么优化,不要写一大堆,分点,你写上去的目的,一是让别人知道你做了这个知识点,然后在面试官技术面的时侯,他知道你会这个,那么就会跟你深挖这个,然后就是个人评价改为专业技能
点赞 评论 收藏
分享
coffrar:全都是已读😅沟通一千五百多个了
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客企业服务