坚持使用vigenere.c

时间:2014-07-19 13:43:59

标签: c encryption cs50 vigenere

  

我被困在这个例子中。每当我把关键字'培根'我得到了错误的答案。     知道为什么会这样吗?我无法找到错误,我已经尝试了很多。     你能帮我吗?

运行时: ./vigenere bacon 并输入文字Meet me at the park at eleven am,答案应该是Negh zf av huf pcfx bt gzrwep oz,而是我得到Negh ne og tjs qaty bt syfvgb bm

  

更新:我根据评论的建议进行了一些更改,但仍然遇到了同样的问题。

#include<cs50.h>
#include<ctype.h>
#include<stdio.h>
#include<string.h>

int main(int argc, char *argv[])
{
    //check if it has only two values
    if (argc != 2)
    {
        printf("Usage: ./vigenere keyword\n");
        return 1;
    }

    // check that every letter of keyword is alphabetic
    char *keyword = argv[1];
    int keylen = strlen(keyword);
    for (int i = 0, n = keylen; i < n; i++)
    {
        if(!isalpha(keyword[i]))
        { 
            printf("alphabetic keyword only!!!\n");
            return 1; 
        }

       if(isalpha(keyword[i]))
       {
           // if a letter of keyword is uppercase
           if (isupper(keyword[i]))
           { 
               keyword[i] = keyword[i] - 'A';
           } 

           // if a letter of keyword is lowercase
           if (islower(keyword[i]))
           {
               keyword[i] = keyword[i] - 'a';   
           } 
       }  
    } 

    char *text = GetString();
    for (int i = 0, n = strlen(text); i < n; i++)
    {    

        if (isalpha(text[i]))
        {
            // if plaintext letter uppercase then...
            if (isupper(text[i]))
            {
                text[i] = ((text[i] - 'A') + (keyword[i % keylen])) % 26 + 'A';
                printf("%c",text[i]);

                                           // ^^^^^^ ----> repeat the pattern
            }

            // if plaintext letter lowercase then ...
            if (islower(text[i]))
            {
                text[i] = ((text[i] - 'a') + (keyword[i % keylen])) % 26 + 'a';
                printf("%c",text[i]);

            }
        }

        // if no letters in plaintext then ...
        if (!isalpha(text[i]))
        { 
            text[i] = text[i];
            printf("%c",text[i]);
        }  
    }
    printf("\n");
}

1 个答案:

答案 0 :(得分:0)

  

因为@BLUEPIXY建议我必须使用不同的变量才能得到正确的答案:

   `char *text = GetString();
    int k = 0;
    for (int i = 0, n = strlen(text); i < n; i++)
    {    

    if (isalpha(text[i]))
    {
       // if plaintext letter uppercase
       if (isupper(text[i]))
       {
            text[i]= ((text[i] - 'A') + (keyword[k % keylen])) % 26 + 'A';
            printf("%c",text[i]);

                                        //^^^^^ ----> repeat the keyword pattern   
       }

            // if plaintext letter lowercase
       if (islower(text[i]))
        {
            text[i] = ((text[i] - 'a') + (keyword[k % keylen])) % 26 + 'a';
            printf("%c",text[i]);

        }
        k++;
     }`