凯撒密码问题(C)

3
这段代码的目的是创建一个凯撒密码,只对字母数字字符进行加密,使用3个密钥,其中第一个字母通过第一个密钥递增,第二个字符通过第二个密钥递增,第三个字符通过第三个密钥递增,第四个字符通过第一个密钥递增等等,同时使用环绕(Z+1-->a),(a-1-->Z)。
我已经完全完成了任务,唯一的问题是我的负数环绕不起作用(a-1-->Z)。它要求输入密钥,接受输入,但是没有返回任何结果(但仍然允许用户输入并按回车键而没有任何结果)。这是我的代码:
#include <stdio.h>
#include <math.h>
#include <string.h>
#include <stdlib.h>

char sentence[101] = { '\0' };
char alphabet[52]={'a','b','c','d','e','f','g','h','i','j','k','l','m','n','o','p','q','r','s','t','u','v','w','x','y','z','A','B','C','D','E','F','G','H','I','J','K','L','M','N','O','P','Q','R','S','T','U','V','W','X','Y','Z'};

int locateletter(char tolocate){
    int i=0;
    for(i=0; i<52; i++){
            if(alphabet[i] == tolocate)
                    return i;
    }
}

int main(void){
    int key1 = 0;
    int key2 = 0;
    int key3 = 0;
    printf("Sentence: ");
    scanf("%101[^\n]", sentence);
    if( sentence[100] != '\0' ){
        printf("You entered more than 100 characters. Block Caesar Cipher is exiting. Goodbye.\n");
        exit;
    }else{
        printf("Keys: ");

        scanf("%d %d %d", &key1, &key2, &key3);
        int i=0;
        for(i=0; i<100; i=i+3){
                if(isalpha(sentence[i])){
                        int position = locateletter(sentence[i]);
                        while((position+key1)>51){
                                key1 = position+key1-52;
                                position=0;
                        }
                        while((position+key1)<0){
                                key1 = key1+position+52;
                                position=0;
                        }
                        sentence[i] = alphabet[position+key1];
                }
        }
        int k=1;
        for(k=1; k<100; k=k+3){
                if(isalpha(sentence[k])){
                        int position = locateletter(sentence[k]);
                        while((position+key2)>51){
                                key2 = position+key2-52;
                                position=0;
                        }
                        while((position+key2)<0){
                                key1 = key2+position+52;
                                position=0;
                        }
                        sentence[k] = alphabet[position+key2];
                }
        }
        int t=2;
        for(t=2; t<100; t=t+3){
                if(isalpha(sentence[t])){
                        int position = locateletter(sentence[t]);
                        while((position+key3)>51){
                                key3 = position+key3-52;
                                position=0;
                        }
                        while((position+key3)<0){
                                key1 = key3+position+52;
                                position=0;
                        }
                        sentence[t] = alphabet[position+key3];
                }
        }
        printf("Cipher: %s\nDone.\n", sentence);

    }
    return 0;
}
1个回答

5
我找到了错误。我的负数循环分配了值给key1而不是key2/3。

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接