【问题标题】:How to make getchar() not get the ENTER I did before?( in C)如何使 getchar() 无法获得我之前所做的 ENTER?(在 C 中)
【发布时间】:2013-05-16 18:08:50
【问题描述】:

问题来了: 我必须阅读一堆数字(学生的成绩),计算他们的平均值,如果平均值低于 70,我必须将一个因子应用于成绩(成绩曲线)+x 或 *x,然后打印学生数量在班级和平均水平。 我已经编写了整个代码,但我的问题是,在我完成输入数字并且需要输入因子公式后,它会跳过因子应该读取输入的部分,就好像 getchar() 得到我的 ENTER从我完成输入数字开始......对不起,我很难解释这个问题,但这里是代码:

    #include <stdio.h>

#define num_of_students 80
int Grades_Array[num_of_students]={0};

int getGrades()
{
    int i=0;
    int grade_checker=0;
    while (grade_checker >= 0)
    {
        scanf("%d", &grade_checker);
        if (grade_checker < 0)
            break;
        Grades_Array[i] = grade_checker;
        i++;
    }
    return i;
}

float averageGrade(int stud_num)
{
    int i=0;
    int total=0;
    float avg_grade=0;
    for (i=0 ; i < stud_num ; i++)
        total = total + Grades_Array[i];
    avg_grade = total / stud_num;
    return avg_grade;
}

void factor(int stud_num)
{
    float i=0;
    int j=0;
    char c=0;
    printf("Please enter a factor formula:\n");
    while ( c!='\n' && c!=EOF)
    {
        c=getchar();
        if ( c == '+' || c == '*')
        {

            scanf("%f", &i);
            break;
        }
    }
    if ( c == '+')
    {
        for (j=0 ; j<stud_num ; j++)
        {
            Grades_Array[j] = Grades_Array[j] + i;
            if (Grades_Array[j] > 100)
                Grades_Array[j] = 100;
        }
    }
    if ( c == '*')
    {
        for (j=0 ; j<stud_num ; j++)
        {
            Grades_Array[j] = Grades_Array[j] * i;
            if (Grades_Array[j] > 100)
                Grades_Array[j] = 100;
        }
    }
}

void printAverage(int stud_num, float average)
{
    printf("Number of students in the course: %d\n", stud_num);
    printf("Average number: %f", average);
}

void main()
{
    int i=getGrades();
    float avg = averageGrade(i);
    if (avg < 70)
        factor(i);
    printAverage(i, avg);
}

这是我的代码,还有一些注意事项: num_of_students 表示班级中的最大学生人数 和 getGrades 函数读取学生的成绩并计算班级 atm 中有多少学生(返回 i)

这是一个输入和输出的例子: 输入 : 57 99 20 60 69 73 44 100 85 66 75 0 87 73 -1(等级) +3(因子公式

输出:

课程学生人数:14 平均成绩:67.500000

任何帮助将不胜感激,感谢您的宝贵时间!

【问题讨论】:

    标签: c input scanf getchar


    【解决方案1】:

    不幸的是,在使用 scanf()、getchar()、fgets() 等时,获取交互式输入是相当有问题的。这就是为什么大多数人通常编写自己的自定义函数,通常从 stdin 获取整行,然后根据到他们的需要。大多数情况下,问题来自 stdin 的行缓冲特性,在许多情况下它没有被刷新,因此之前读取的剩余部分会提供给下一个读取(顺便说一句,这里是 good ol' read,ihmo)。

    我不太确定我是否在您的代码中确定了所有可能的情况,但这里有一个版本,它似乎只需要很少的更改即可工作。基本上,我编写了一个简单的 flush_stdin() 函数,并稍微更改了您的 scanf() 调用(添加了错误检查,重新安排了一些代码等)。我还在你的 factor() 函数中删除了 getchar(),并替换了我认为你试图用 scanf() 做的事情。

    在此过程中,我修复了一些与原始问题无关的问题(例如,我在您的 averageGrade() 函数中添加了一个健全性检查,以防止除以零运行时错误)。

    它似乎工作正常,但我没有进行广泛的测试。请注意,一般来说,处理交互式输入的首选方式是通过自定义函数(例如,GNU 推荐使用他们的 getline() and getdelim() 扩展来从流中读取行)。

    这里是代码,希望对你有帮助...

    #include <stdio.h>
    #include <stdlib.h>
    
    #define num_of_students 80
    
    int Grades_Array[num_of_students] = {0};
    
    /* -------------------------------------- */
    void flush_stdin(void)
    {
        int c;
        while ( !feof(stdin) && '\n' != (c=getchar()) && EOF != c )
            ;   /* void */
    }
    /* -------------------------------------- */
    int getGrades( void )
    {
        int i     = 0;
        int grade = 0;
    
        for (;;)
        {
            if ( 1 != scanf("%d", &grade) || grade < 0 )
                break;
            Grades_Array[i++] = grade;
        }
        flush_stdin();
    
        return i;
    }
    /* -------------------------------------- */
    float averageGrade(int stud_num)
    {
        int i = 0;
        int total = 0;
        float   avg_grade = 0;
    
        /* avoid division by zero */
        if ( 0 == stud_num )
            return -1.0;
    
        for (i=0; i < stud_num; i++)
            total += Grades_Array[i];
    
        avg_grade = total / stud_num;
    
        return avg_grade;
    }
    /* -------------------------------------- */
    void factor(int stud_num)
    {
        float   i = 0;
        int j = 0;
        char    c = '\0';
    
        printf("Please enter a factor formula:\n");
        if ( 2 != scanf(" %c%f", &c, &i) )  /* skip leading blanks, then read c and i */
            return;
    
        for (j=0; j < stud_num; j++)
        {
            if ( '+' == c )
                Grades_Array[j] += i;
            else if ( '*' == c )
                Grades_Array[j] *= i;
            else
                break;
    
            if ( Grades_Array[j] > 100 )
                Grades_Array[j] = 100;
        }
    }
    
    /* -------------------------------------- */
    void printAverage( int stud_num, float average )
    {
        printf("Number of students in the course: %d\n", stud_num);
        printf("Average number: %f\n", average);
    }
    
    /* -------------------------------------- */
    int main( void )
    {
        int i     = getGrades();
        float avg = averageGrade(i);
    
        if (avg < 70)
            factor(i);
        printAverage(i, avg);
    
        exit(0);
    }
    

    【讨论】:

    • 太棒了!非常感谢您的帮助,您的代码在我需要检查的所有输入上都运行良好,非常感谢您发送给我的链接,因为我在下一个家庭作业中也必须处理同样的事情.你很容易让我开心!我希望你有一个美好的周末:)
    • 很高兴为您提供帮助(顺便说一句,您也应该将帖子标记为 homework)。
    • @HarryK。不,不,他不应该。 homework 标签是 deprecated, nuked, and blacklisted
    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 2011-04-27
    • 2015-02-04
    • 1970-01-01
    • 2023-03-24
    • 2015-02-07
    • 1970-01-01
    相关资源
    最近更新 更多