我正在用 C++ 创建一个程序,它使用 Caesar Cipher 加密文本,它允许用户选择用于加密的偏移量,当我为偏移量 1 编写它时,但是当我使用 replace() 函数时STL 的一部分,而不是用指定的字符替换它们,而是将它们全部替换为相同的字母
#include <iostream>
#include <string>
#include <algorithm>
using namespace std;
int main()
{
int Offset;
string Message;
cout << "What Would You Like To Offset By" << endl;
cin >> Offset;
cout << "Please Enter The Text You Would Like To Encrypt" << endl;
cin >> Message;
switch(Offset)
{
case 1:
{
replace(Message.begin(), Message.end(), 'a', 'b');
replace(Message.begin(), Message.end(), 'A', 'B');
replace(Message.begin(), Message.end(), 'b', 'c');
replace(Message.begin(), Message.end(), 'B', 'C');
replace(Message.begin(), Message.end(), 'c', 'd');
replace(Message.begin(), Message.end(), 'C', 'D');
replace(Message.begin(), Message.end(), 'd', 'e');
replace(Message.begin(), Message.end(), 'D', 'E');
replace(Message.begin(), Message.end(), 'e', 'f');
replace(Message.begin(), Message.end(), 'E', 'F');
replace(Message.begin(), Message.end(), 'f', 'g');
replace(Message.begin(), Message.end(), 'F', 'G');
replace(Message.begin(), Message.end(), 'g', 'h');
replace(Message.begin(), Message.end(), 'G', 'H');
replace(Message.begin(), Message.end(), 'h', 'i');
replace(Message.begin(), Message.end(), 'H', 'I');
replace(Message.begin(), Message.end(), 'i', 'j');
replace(Message.begin(), Message.end(), 'I', 'J');
replace(Message.begin(), Message.end(), 'j', 'k');
replace(Message.begin(), Message.end(), 'J', 'K');
replace(Message.begin(), Message.end(), 'k', 'l');
replace(Message.begin(), Message.end(), 'K', 'L');
replace(Message.begin(), Message.end(), 'l', 'm');
replace(Message.begin(), Message.end(), 'L', 'M');
replace(Message.begin(), Message.end(), 'm', 'n');
replace(Message.begin(), Message.end(), 'M', 'N');
replace(Message.begin(), Message.end(), 'n', 'o');
replace(Message.begin(), Message.end(), 'N', 'O');
replace(Message.begin(), Message.end(), 'o', 'p');
replace(Message.begin(), Message.end(), 'O', 'P');
replace(Message.begin(), Message.end(), 'p', 'q');
replace(Message.begin(), Message.end(), 'P', 'Q');
replace(Message.begin(), Message.end(), 'q', 'r');
replace(Message.begin(), Message.end(), 'Q', 'R');
replace(Message.begin(), Message.end(), 'r', 's');
replace(Message.begin(), Message.end(), 'R', 'S');
replace(Message.begin(), Message.end(), 's', 't');
replace(Message.begin(), Message.end(), 'S', 'T');
replace(Message.begin(), Message.end(), 't', 'u');
replace(Message.begin(), Message.end(), 'T', 'U');
replace(Message.begin(), Message.end(), 'u', 'v');
replace(Message.begin(), Message.end(), 'U', 'V');
replace(Message.begin(), Message.end(), 'v', 'w');
replace(Message.begin(), Message.end(), 'V', 'W');
replace(Message.begin(), Message.end(), 'w', 'x');
replace(Message.begin(), Message.end(), 'W', 'X');
replace(Message.begin(), Message.end(), 'x', 'y');
replace(Message.begin(), Message.end(), 'X', 'Y');
replace(Message.begin(), Message.end(), 'y', 'z');
replace(Message.begin(), Message.end(), 'Y', 'Z');
replace(Message.begin(), Message.end(), 'z', 'a');
replace(Message.begin(), Message.end(), 'Z', 'A');
cout << Message << endl;
break;
}
}
}
答案 0 :(得分:4)
计算机编程的黄金法则指出:“您的计算机总是完全按照您的要求执行,而不是您希望它执行的操作”。
现在让我们探索您让计算机执行的操作。
replace(Message.begin(), Message.end(), 'a', 'b');
您告诉计算机将每次出现的字母 'a'
替换为字母 'b'
。您的计算机将完全做到这一点。两个声明之后:
replace(Message.begin(), Message.end(), 'b', 'c');
在这里,您告诉计算机将每次 出现的字母 'b'
替换为字母 'c'
。您的计算机将完全做到这一点。这包括原始文本中的字母“b”,以及所有原本是“a”但现在是“b”的字母。那是因为,之前您告诉计算机将所有 a-s 更改为 b-s,现在您有一堆 b
,而现在所有这些都无法区分了。
以这种方式,如果您在纸上计算出您告诉计算机执行的所有操作的结果是什么,很明显为什么结果字符串总是以相同的字母结尾(实际上,两个字母都是大写的)和小写)。
您在这里的明显目标是用下一个字母替换每个字母,并旋转。正确的方法会完全不同,但这解释了为什么文本被替换为“全部用相同的字母”。
答案 1 :(得分:0)
你的文字让我很好奇,所以我尝试了另一种方法:
以ax3 =plt.subplot2grid((2,2),(1,1), colspan = 1)
为字符串;
将字符转换为 cin
然后 (ASCII + offset) % 128
再次变为 cout
。
如果你有兴趣,我可以提供代码,但不想给你机会,自己解决,(以无数可能的方式之一):)