gpt4 book ai didi

C++ Enigma::解码消息

转载 作者:塔克拉玛干 更新时间:2023-11-03 07:57:32 27 4
gpt4 key购买 nike

大家好,我正在开发一个程序,您可以选择将消息(字符串)转换为 3 种不同的方案:Prime Shift 编码方案、Shifty 编码方案和反向编码方案。我已经弄清楚如何编码和解码素数移位方案和反向方案,但我在使用移位编码方案时遇到了一些麻烦。 Shifty 方案的规则如下: 消息中的每个字符都转换为其 ASCII 值。从 1000 中减去该值,得到三元组数字。然后将三元组的每个数字转换为键盘上数字 1 – 0 上方的符号值。符号串是编码消息。

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

然后将编码后的消息连同 key 以及与方案相对应的数字一起存储在文本文件中。当用户点击解码按钮时,文件选择器打开,用户选择要读入的文本文件。一旦他/她选择了他们想要打开的文件,程序就会在编码消息中读取 key 和方案。因此程序必须能够获取编码后的消息并将其转换回其原始消息。

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

到目前为止我有这个:

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)
{
}
}

最佳答案

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

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*/ }
}

关于C++ Enigma::解码消息,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16135051/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com