0

已修复:嘿,当我尝试计算文本中的单词时,我在 C 中遇到了这个奇怪的分段错误。谁能解释一下段错误的原因和解决方案?

这是我的源代码:

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

int isword(char *str) {
    return (isalnum(*(str + 1))) ? 1 : 0;
}

int main() {
    char **text, c;
    int n, i, j;

    //reading from stdin & allocating it dynamically
    scanf("%d\n", &n);
    text = malloc(n * sizeof(char *));
    for(i = 0; i < n; i++) {
        text[i] = malloc(200 * sizeof(char));
    }

    for(i = 0; i < n; i++) {
        for(j = 0; ; j++) {
            scanf("%c", &c);
            if(c == '\n') {
                break;
            }
            text[i][j] = c;
        }
    }

    // Counting words
    int word_counter = 0;
    char *delimitor = " ";
    char *pos;
    for(i = 0; i < n; i++) {
        pos = text[i];
        do {
            if(isspace(*pos) && isword(pos)) {
                word_counter++;
            }
            pos ? pos++ : pos;
            // pos++;
        } while(*pos != '\0');
    }

    printf("Number of words: %d\n", word_counter);
    return 0;
}

输入示例:

4
Adam baked a pie.
Mary   went         to a movie
Mark goes like ?? him
Gina is, hot

请注意第二句中空格的过度使用。

我还有另一个关于我阅读的问题stdin。有没有更好的方法来实现这一目标?我的意思是我试图用 来做fgets,但我失败了,我知道我不应该使用gets(见鬼,如果你使用 get,即使 GCC 也会将它作为警告)。

另一个问题:为什么它不打印预期的字数?它打印 12 而不是 14?

4

1 回答 1

3
    pos ? pos++ : pos;
    // pos++;
} while(pos != '\0');

    *pos ? pos++ : pos;
    // pos++;
} while(*pos != '\0');
于 2013-12-08T17:53:49.373 回答