我一直在研究 cs50 pset2,我认为在研究了几天之后我已经掌握了 vigenere 密码。此代码旨在采用用户给出的字母参数(argv []),并将其用作密钥,通过其在字母索引中的编号来加密用户(字符串)给出的短语。例如,如果您给出参数 'abc' 和字符串 'cat',那么输出应该是 'cbv'(a 移动 0,b 移动 1,c 移动 2) 参数也应该环绕,这样如果字符串是更长的时间,参数将换行到它的第一个字符并继续直到字符串结束。
这就是我的代码:
#include <cs50.h>
#include <stdio.h>
#include <string.h>
#include <ctype.h>
int main(int argc, string argv[])
{
if(argc != 2)
{
printf("Try again\n");
return 1;
}
string k = (argv[1]);
int klen = strlen(k);
for(int x = 0; x < klen; x++)
{
if(isalpha(k[x]))
{
if(isupper(k[x]))
{
k[x] = tolower(k[x]);
}
k[x] -= 'a';
}
else
{
printf("Try again\n");
return 1;
}
}
string code = GetString();
int clen = strlen(code);
for(int a = 0, b = 0; a < clen; a++)
{
if(isalpha(code[a]))
{
int key = k[b%klen];
if(isupper(code[a]))
{
printf("%c", (((code[a] - 'A') + key)%26) + 'A');
b++;
}
else
{
printf("%c", (((code[a] - 'a') + key)%26) + 'a');
b++;
}
}
else
{
printf("%c", code[a]);
}
}
printf("\n");
}
该代码似乎适用于键 +1 的长度。例如,我输入一个参数'aaaa'
然后输入一串'bbbbb',正确接收'bbbbb'。
但是,如果我输入相同的 'aaaa'
然后输入一个比键长的字符串 +1 'bbbbbbb' 我收到 'bbbbbNN'
我相信我的操作顺序有问题,但尝试移动括号无济于事。我希望有人能指出我正确的方向,为什么我的钥匙没有正确包装。