0

为什么在这段代码中它会执行无限循环而不再次提示用户

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

void to_rot13(char* value);

int main(){
    char word[1024];
    printf("C ROT13\nSome data to code or decode\n");
    while (1){
        printf(": ");
        scanf("%[^\n]s", word);
        to_rot13(&word);
        printf(": %s\n", word);
    }
    return 0;
}


void to_rot13(char* value){
    unsigned int x;
    for (x = 0; value[x] != '\0'; x++){
        if ((value[x] < 'A') || (value[x] > 'Z' && value[x] < 'a') || (value[x] > 'z')){}
        else if (tolower(value[x]) <= 'm'){value[x] = value[x] + 13;}
        else{value[x] = value[x] - 13;}
    }
}

我想再次提示用户我不能更精确。

4

2 回答 2

3
scanf("%[^\n]s", word);

将换行符留在输入缓冲区中,因此下一个scanf立即返回而不读取任何进一步的输入,因为char缓冲区中的第一个左侧是换行符。您需要从输入缓冲区中删除换行符。

int c;
do {
    c = getchar();
}while(c != '\n' && c != EOF);
if (c == EOF) {
    exit(EXIT_FAILURE); // input borked
}

此外,请注意编译器的警告并传递word而不是&wordto to_rot13

于 2012-11-01T20:02:51.557 回答
1

您正在发送 &word 到to_rot13(您应该发送 word 或 &word[0])

于 2012-11-01T20:02:27.767 回答