【嵙大OJ】Problem 1177:成绩统计

Problem A: 成绩统计

Time Limit: 1 Sec   Memory Limit: 16 MB
Submit: 4407   Solved: 1878
[ Submit][ Status][ Web Board]

Description

把百分制的考试成绩转换为五个等级:
90~100:Excellent
80~89:Good
70~79:Average
60~69:Pass
0~59:Failing
统计每个等级的成绩,并输出。

Input

输入多行,每行一个整数。输入的成绩总数不超过1000个。到EOF结束。

Output

按从好到差的顺序分等级输出成绩,第一行为“等级 : 成绩数”,成绩数为这一等级的成绩总数;第二行为具体的成绩,用逗号分隔开,每个逗号后面有空格,每行最后一个成绩后没有逗号和空格。最后一行后有回车。输出的成绩与输入的顺序相同。若某个等级没有成绩,则不输出第二行。
具体格式参照sample。

Sample Input

-1
81
92
35
68
72
100
1000
95
60
59
72

Sample Output

Excellent : 3
92, 100, 95
Good : 1
81
Average : 2
72, 72
Pass : 2
68, 60
Failing : 2
35, 59

HINT

如果没有不及格的成绩,你的程序还能否正确运行吗?


#include 
#include 
int statistics(int I, int g1, int arr[])
{
    int i, sum = 0, g2 = g1 - 9;
    if(g1 == 59)
        g2 = 0;
    if(g1 == 99)
        g1 = 100;
    for(i = 0; i < I; i++)
        if(arr[i] <= g1 && arr[i] >= g2)
            sum++;
    if(g1 == 100)
        printf("Excellent : ");
    else if(g1 == 89)
        printf("Good : ");
    else if(g1 == 79)
        printf("Average : ");
    else if(g1 == 69)
        printf("Pass : ");
    else if(g1 == 59)
        printf("Failing : ");

        printf("%d\n", sum);
        if(sum == 0)
        {
            //printf("\n");  // 原来不输出第二行是这个意思-_-|||
            return 0;
        }
        else
        {
            for(i = 0; ; i++)
            {
                if(arr[i] <= g1 && arr[i] >= g2)
                {
                    printf("%d", arr[i]);
                    break;
                }
            }
            for(i += 1; i < I; i++)
                if(arr[i] <= g1 && arr[i] >= g2)
                    printf(", %d", arr[i]);
            printf("\n");
            return 0;
        }

}
int main()
{
    int arr[1000], i, j, grade;
    for(i = 0; scanf("%d", &arr[i]) != EOF; i++);
    for(j = 1, grade = 99; j <= 5; j++, grade -= 10)
        statistics(i, grade, arr);
    return 0;
}

你可能感兴趣的:(【嵙大OJ】Problem 1177:成绩统计)