嘿,我正在开发一个程序,它提供了将消息(字符串)转换为3种不同方案的选项:主移位编码方案、移位编码方案和反向编码方案。我已经知道如何编码和解码素数移位方案和反转方案,但我在使用Shifty编码方案时遇到了一点麻烦。Shifty方案的规则如下:将消息中的每个字符转换为其ASCII值。从1000中减去该值,得到一个三元组的数字。然后,将三元组的每个数字转换为数字1- 0上方的键盘上的符号值。符号串是编码后的消息。
例如,如果字符的值是37,则从1000中减去它,得到一个三元组963。对应的键盘字符为(^#。
然后,将编码的消息与密钥和对应于该方案的号码一起存储在文本文件中。当用户单击解码按钮时,文件回显程序打开,用户选择要读入的文本文件。一旦他/她选择了他们想要打开的文件,程序就读取编码后的消息、密钥和方案。因此,程序必须能够获取编码后的消息并将其转换回原始消息。
我已经弄清楚了编码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)
{
}
}发布于 2013-04-22 03:12:53
我们从创建符号的反向查找开始。我使用0表示无效数字,因为默认情况下数组初始化为0,并使用10标记数字0。您循环遍历输入的每个字符,并在antiKeyboard数组上使用反向查找,以查看它映射到哪个数字。如果反向查找返回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*/ }
} https://stackoverflow.com/questions/16135051
复制相似问题