K& R练习4-3

时间:2014-01-10 16:33:55

标签: c kernighan-and-ritchie

我刚刚解决了练习4-10 - 我用getline替换了(unget / get)char,但是我无法添加对负数的支持。推理很简单,如果char是' - '并且它旁边的字符是数字或小数点,我们有一个负数。我不知道我做错了什么,第一次尝试这样的事情:

if(c != '-' && isdigit(line[lp])) {
    return c;
}

如果我们有一个负数,则不应该执行第2行,并且数组s将第一个元素作为' - '。但是,我得到一个无限循环,我找不到问题。

这是此问题最相关的代码段(尤其是getop中的第4个if语句)。

#define MAXLINE 100
char line[MAXLINE];
int lp = 0;
int lineLength  = 0;
int getline(char s[], int lim) {
    int i, c;
    i = 0;
    while(--lim > 0 && (c = getchar()) != EOF && c != '\n')
        s[i++] = c;
    if(c == '\n')
        s[i++] = c;
    s[i] = '\0';
    return i;
}
int getop(char s[]) {
    if(lp  == lineLength) {
        lineLength = getline(line, MAXLINE);
        lp = 0;
    }
    if(lineLength == 0)
        return EOF;
    char c;
    int i;
    printf("the execution is here\n");
    while((s[0] = c = line[lp++]) == ' ' || c == '\t')
        /* skip tabs an white spaces */;
    s[1] = '\0';
    if(!isdigit(c) && c != '.' && c != '-')
        return c;
    if(c == '-') {
        if(isdigit(line[lp]) || line[lp] == '.')
            /* nothing */;
       else
            return c;
    }
    i = 0;
    if(isdigit(c))
        while(isdigit((s[++i] = c = line[lp++])))
            ;
    if(c == '.')
        while(isdigit((s[++i] = c = line[lp++])))
            ;
    lp--;
    return NUMBER;
}

1 个答案:

答案 0 :(得分:0)

当您找到' - '时,您需要提前lp。函数底部的if不是' - '。在函数返回之前,您会注意到其他数字(和小数点)前进lp,因此您需要将“ - ”符号复制到s[](或将其存储在全局标志中)并增加{ {1}},否则它只是一遍又一遍地处理相同的字符。

如果您查看lp对正数和负数的影响,单步执行调试器中的代码也可以帮助您查看问题。