K& R练习1-13

时间:2013-07-12 03:12:32

标签: c

练习是

“编写程序以打印输入中单词长度的直方图。”

这是答案书中给出的答案。由于某种原因,它在CodeBlocks中不起作用,因为当我输入输入时没有任何输出。为什么会这样?

另一个问题是关于wl[i];那是什么?

#include <stdio.h>

#define MAXHIST 15
#define MAXWORD 11
#define IN      1
#define OUT     0

main()
{
    int c, i, nc, state;
    int len;
    int maxvalue;
    int ovflow;
    int wl[MAXWORD];

    state = OUT;
    nc = 0;
    ovflow = 0;
    for(i=0; i < MAXWORD; ++i)
        wl[i] = 0;
    while(( c = getchar()) !=EOF) {
        if (c==' '|| c=='\n'|| c == '\t' ){
            state = OUT;
            if (nc>0)
                if (nc < MAXWORD)
                    ++wl[nc];
                else
                    ++ovflow;

            nc=0;
        }else if (state == OUT){
            state = IN;
            nc = 1;
        }else
            ++nc;
    }
    maxvalue = 0;
    for (i = 1; 1<MAXWORD; ++i)
        if (wl[i] > maxvalue)
            maxvalue = wl[i];

    for (i=1; i<MAXWORD; ++i){
        printf("%5d - %5d : ", i, wl[i]);
        if (wl[i]> 0){
            if ((len=wl[i] * MAXHIST / maxvalue) <=0)
                len = 1;
        }else
            len = 0;
        while (len > 0 ) {
            putchar('*');
            --len;
        }
        putchar('\n');
    }
    if (ovflow > 0)
            printf("There are %d words >= %d\n", ovflow, MAXWORD);
}

1 个答案:

答案 0 :(得分:3)

这一行错了:

for (i = 1; 1 < MAXWORD; ++i)

第二个1当然应该是i。在1不小于11之前很长一段时间。另一方面,你然后阅读全部内存,迟早,你会读到一些不可读的东西,程序应该崩溃。它有可能不会崩溃,但行为是未定义的,所以发生的任何事情都可以。