维吉尼亚密码
Vigenere Cipher
我在 运行 下面为 vigenere cipher.even 设计的代码时遇到了问题 cipher.even 在彻底完成之后我无法调试问题。它显示 error:killed by server.please 的帮助。
/**
*
* vigenere.c
*
* Abhishek kumar
* encrypts entered string using vigenere cipher
* */
#include <stdio.h>
#include <stdlib.h>
#include <cs50.h>
#include <ctype.h>
#include <string.h>
int main(int argc, string argv[] )
{
if (argc != 2)
{
printf("Usage: /home/cs50/pset2/vigenere <keyword>");
return 1;
}
if (argc == 2)
{ string key = argv[1];
for(int k = 0,l = strlen(key);k < l; k++)
{
if(!isalpha(key[k]))
{
printf("Keyword must only contain letters A-Z and a-z");
exit(1);
}
}
string txt = GetString();
int i = 0,j = 0,c = 0;
int n = strlen(txt);
int m = strlen(key);
while(i < n)
{
if (isupper(txt[i]))
{
if(isupper(key[j]))
{
c = ((((int) txt[i] - 65 + (int) key[j] -65)%26) + 65);
printf("%c", (char) c);
i++;
j++;
}
if(islower(key[j]))
{
c = ((((int) txt[i] - 65 + (int) key[j] -97)%26) + 65);
printf("%c", (char) c);
i++;
j++;
}
}
else if (islower(txt[i]))
{
if(isupper(key[j]))
{
c = ((((int) txt[i] - 97 + (int) key[j] -65)%26) + 97);
printf("%c", (char) c);
i++;
}
if(islower(key[j]))
{
c = ((((int) txt[i] - 97 + (int) key[j] -97)%26) + 97);
printf("%c", (char) c);
j++;
}
}
else
{
printf("%c",txt[i]);
i++;
}
if (j == m-1)
{
j = 0;
}
}
}
}
下面是它失败的一些测试用例。
:) vigenere.c exists
:) vigenere.c compiles
:( encrypts "a" as "a" using "a" as keyword
\ killed by server
:( encrypts "world, say hello!" as "xoqmd, rby gflkp!" using "baz" as keyword
\ killed by server
:( encrypts "BaRFoo" as "CaQGon" using "BaZ" as keyword
\ expected output, but not "CGSFpp"
:( encrypts "BARFOO" as "CAQGON" using "BAZ" as keyword
\ expected output, but not "CASFPO"
:) handles lack of argv[1]
:) handles argc > 2
:) rejects "Hax0r2" as keyword
在 islower(txt[i])
部分,您无法在所有情况下递增 i
和 j
。在你不增加 i
的地方,即键的第一个字符和文本都是小写的地方,你最终会陷入无限循环。
在 isupper(txt[i])
部分,您在 isupper(key[j])
部分递增 i
和 j
,然后输入 islower(key[j])
部分,因为您使用 if
而不是 else if
.
对于以上两个,将if(islower(key[j]))
更改为else if(islower(key[j]))
,并在每个内部if
块之后移动j++
和printf
。至于 i
,将 while
更改为 for
并增加 i
作为其中的一部分。
在检查您是否应该重置 j
时,您偏离了 1。m-1
是 key
的有效索引,因此您还不想重置.在 j == m
.
时执行
此外,将 ASCII 码替换为它们代表的实际字符,这样您的操作就更清楚了。也不需要强制转换。
for (i=0; i < n; i++)
{
if (isupper(txt[i]))
{
if(isupper(key[j]))
{
c = (((txt[i] - 'A' + key[j] -'A')%26) + 'A');
}
else if(islower(key[j]))
{
c = (((txt[i] - 'A' + key[j] -'a')%26) + 'A');
}
printf("%c", c);
j++;
}
else if (islower(txt[i]))
{
if(isupper(key[j]))
{
c = (((txt[i] - 'a' + key[j] -'A')%26) + 'a');
}
else if(islower(key[j]))
{
c = (((txt[i] - 'a' + key[j] -'a')%26) + 'a');
}
printf("%c", c);
j++;
}
else
{
printf("%c",txt[i]);
}
if (j == m)
{
j = 0;
}
}
我在 运行 下面为 vigenere cipher.even 设计的代码时遇到了问题 cipher.even 在彻底完成之后我无法调试问题。它显示 error:killed by server.please 的帮助。
/**
*
* vigenere.c
*
* Abhishek kumar
* encrypts entered string using vigenere cipher
* */
#include <stdio.h>
#include <stdlib.h>
#include <cs50.h>
#include <ctype.h>
#include <string.h>
int main(int argc, string argv[] )
{
if (argc != 2)
{
printf("Usage: /home/cs50/pset2/vigenere <keyword>");
return 1;
}
if (argc == 2)
{ string key = argv[1];
for(int k = 0,l = strlen(key);k < l; k++)
{
if(!isalpha(key[k]))
{
printf("Keyword must only contain letters A-Z and a-z");
exit(1);
}
}
string txt = GetString();
int i = 0,j = 0,c = 0;
int n = strlen(txt);
int m = strlen(key);
while(i < n)
{
if (isupper(txt[i]))
{
if(isupper(key[j]))
{
c = ((((int) txt[i] - 65 + (int) key[j] -65)%26) + 65);
printf("%c", (char) c);
i++;
j++;
}
if(islower(key[j]))
{
c = ((((int) txt[i] - 65 + (int) key[j] -97)%26) + 65);
printf("%c", (char) c);
i++;
j++;
}
}
else if (islower(txt[i]))
{
if(isupper(key[j]))
{
c = ((((int) txt[i] - 97 + (int) key[j] -65)%26) + 97);
printf("%c", (char) c);
i++;
}
if(islower(key[j]))
{
c = ((((int) txt[i] - 97 + (int) key[j] -97)%26) + 97);
printf("%c", (char) c);
j++;
}
}
else
{
printf("%c",txt[i]);
i++;
}
if (j == m-1)
{
j = 0;
}
}
}
}
下面是它失败的一些测试用例。
:) vigenere.c exists
:) vigenere.c compiles
:( encrypts "a" as "a" using "a" as keyword
\ killed by server
:( encrypts "world, say hello!" as "xoqmd, rby gflkp!" using "baz" as keyword
\ killed by server
:( encrypts "BaRFoo" as "CaQGon" using "BaZ" as keyword
\ expected output, but not "CGSFpp"
:( encrypts "BARFOO" as "CAQGON" using "BAZ" as keyword
\ expected output, but not "CASFPO"
:) handles lack of argv[1]
:) handles argc > 2
:) rejects "Hax0r2" as keyword
在 islower(txt[i])
部分,您无法在所有情况下递增 i
和 j
。在你不增加 i
的地方,即键的第一个字符和文本都是小写的地方,你最终会陷入无限循环。
在 isupper(txt[i])
部分,您在 isupper(key[j])
部分递增 i
和 j
,然后输入 islower(key[j])
部分,因为您使用 if
而不是 else if
.
对于以上两个,将if(islower(key[j]))
更改为else if(islower(key[j]))
,并在每个内部if
块之后移动j++
和printf
。至于 i
,将 while
更改为 for
并增加 i
作为其中的一部分。
在检查您是否应该重置 j
时,您偏离了 1。m-1
是 key
的有效索引,因此您还不想重置.在 j == m
.
此外,将 ASCII 码替换为它们代表的实际字符,这样您的操作就更清楚了。也不需要强制转换。
for (i=0; i < n; i++)
{
if (isupper(txt[i]))
{
if(isupper(key[j]))
{
c = (((txt[i] - 'A' + key[j] -'A')%26) + 'A');
}
else if(islower(key[j]))
{
c = (((txt[i] - 'A' + key[j] -'a')%26) + 'A');
}
printf("%c", c);
j++;
}
else if (islower(txt[i]))
{
if(isupper(key[j]))
{
c = (((txt[i] - 'a' + key[j] -'A')%26) + 'a');
}
else if(islower(key[j]))
{
c = (((txt[i] - 'a' + key[j] -'a')%26) + 'a');
}
printf("%c", c);
j++;
}
else
{
printf("%c",txt[i]);
}
if (j == m)
{
j = 0;
}
}