首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >C++ Enigma::解码消息

C++ Enigma::解码消息
EN

Stack Overflow用户
提问于 2013-04-22 03:03:05
回答 1查看 2.2K关注 0票数 2

嘿,我正在开发一个程序,它提供了将消息(字符串)转换为3种不同方案的选项:主移位编码方案、移位编码方案和反向编码方案。我已经知道如何编码和解码素数移位方案和反转方案,但我在使用Shifty编码方案时遇到了一点麻烦。Shifty方案的规则如下:将消息中的每个字符转换为其ASCII值。从1000中减去该值,得到一个三元组的数字。然后,将三元组的每个数字转换为数字1- 0上方的键盘上的符号值。符号串是编码后的消息。

例如,如果字符的值是37,则从1000中减去它,得到一个三元组963。对应的键盘字符为(^#。

然后,将编码的消息与密钥和对应于该方案的号码一起存储在文本文件中。当用户单击解码按钮时,文件回显程序打开,用户选择要读入的文本文件。一旦他/她选择了他们想要打开的文件,程序就读取编码后的消息、密钥和方案。因此,程序必须能够获取编码后的消息并将其转换回原始消息。

我已经弄清楚了编码Shifty方案的代码,它完美地编码了消息,但我不知道如何解码消息。我知道我必须以某种方式从编码的字符串中获得三元组中的每一个,然后从每个数字中减去1000,这样我才能获得正确的ascii字符,但我不知道如何做到这一点。任何帮助都将不胜感激。

到目前为止,我有这样的想法:

代码语言:javascript
复制
ShiftyEnigma::ShiftyEnigma()
{
    keyBoard[0] = ')';
    keyBoard[1] = '!';
    keyBoard[2] = '@';
    keyBoard[3] = '#';
    keyBoard[4] = '$';
    keyBoard[5] = '%';
    keyBoard[6] = '^';
    keyBoard[7] = '&';
    keyBoard[8] = '*';
    keyBoard[9] = '(';
}

void ShiftyEnigma::encode()
{
    stringstream ss;
    stringstream s1;
    int value = 0;
    for(unsigned int i = 0; i < codedMessage.length(); ++i)
    {
        int ascii = codedMessage.at(i);
        //subtracting 1000 from ascii number of each character in message
        value = 1000 - ascii;
        //setting the value in string stream in order to convert each digit of 
        //triplet (ex 887) into values that match the keyboard array
        ss << value;
        for(unsigned int i = 0; i < ss.str().length(); ++i)
        {
            s1 << keyBoard[(int)ss.str().at(i)-48];
        }
        ss.str("");
    }
    codedMessage = s1.str();
}
void ShiftyEnigma::decode()
{
    for(unsigned int i = 0; i < codedMessage.length(); ++i)
    {
    }
}
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2013-04-22 03:12:53

我们从创建符号的反向查找开始。我使用0表示无效数字,因为默认情况下数组初始化为0,并使用10标记数字0。您循环遍历输入的每个字符,并在antiKeyboard数组上使用反向查找,以查看它映射到哪个数字。如果反向查找返回0,那么我们发现了一个无效字符。我选择忽略它,但您可能会显示一条错误消息。现在我们需要获取3个有效的数字,并将它们组合在一起。要将3位数组合成3位数,我们可以这样做: number = digit1 * 100 + digit2 * 10 + digit。我在一个循环中做这件事。

代码语言:javascript
复制
int antiKeyboard[256]= {0};
antiKeyboard['!'] = 1;
antiKeyboard['@'] = 2;
antiKeyboard['#'] = 3;
antiKeyboard['$'] = 4;
antiKeyboard['%'] = 5;
antiKeyboard['^'] = 6;
antiKeyboard['&'] = 7;
antiKeyboard['*'] = 8;
antiKeyboard['('] = 9;
antiKeyboard[')'] = 10; //Note this is 0, but i put is as 10

int digits = 0, digit, number=0;
for(unsigned int i = 0; i < codedMessage.length(); ++i)
{
   digit = antiKeyboard[codedMessage.at(i)];
   if (digit >=1 && digit <=10){
       ++digits;
       number = number * 10 + (digit % 10); //note modulo 10 converts 10 back to 0.
       if (digits == 3){
          printf("%c",1000-number);
          digits = 0;
          number = 0;
       }
    }else{ /*Invalid character, ignoring*/ }
}  
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/16135051

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档