zoukankan      html  css  js  c++  java
  • 假期编程

    此博客链接:https://www.cnblogs.com/ping2yingshi/p/12272828.html

    求平均成绩(73min)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2023

    Problem Description
    假设一个班有n(n<=50)个学生,每人考m(m<=5)门课,求每个学生的平均成绩和每门课的平均成绩,并输出各科成绩均大于等于平均成绩的学生数量。
    Input
    输入数据有多个测试实例,每个测试实例的第一行包括两个整数n和m,分别表示学生数和课程数。然后是n行数据,每行包括m个整数(即:考试分数)。
    Output
    对于每个测试实例,输出3行数据,第一行包含n个数据,表示n个学生的平均成绩,结果保留两位小数;第二行包含m个数据,表示m门课的平均成绩,结果保留两位小数;第三行是一个整数,表示该班级中各科成绩均大于等于平均成绩的学生数量。
    每个测试实例后面跟一个空行。
    Sample Input
    2 2
    5 10
    10 20
    Sample Output
    7.50 15.00
    7.50 15.00
    1
    题解:此题目不难,但是就是饶人,尤其是求每门课程的平均成绩时,要把课程放在外层循环中,学生人数放内层循环,但是这里我一直没有ac了,提示时格式错误,因为每求一个同一类的平均值,后面都要有一个空格,这里需要考虑最后一个平均值时没有空格的,这里我也把最后一个平均值单独计算,但是还是格式错误,我真不知道那里错了。
    代码如下:
    #include<stdio.h>
    #include<math.h>
    #include<stdlib.h>
    int main(void)
    {
        int n; 
        int m;
        while(~scanf("%d %d",&m,&n))
        { 
            int c[100][100];
            int i;
            int j;
            int sum;
            int count=0;
            double avgstudentsore=0.0;//学生平均成绩
            double avgcouse=0;//课程平均成绩
            for(i=0;i<m;i++)
                for(j=0;j<n;j++)
                    scanf("%d",&c[i][j]);
            for(i=0;i<m-1;i++)//求每个学生的平均成绩
            {
                 avgstudentsore=0.0;
                for(j=0;j<n;j++)
                {
                   avgstudentsore+=c[i][j];
                }
                printf("%0.2lf ",avgstudentsore/n);
            }
                avgstudentsore=0.0;
            for(j=0;j<n;j++)//最后一个学生的平均成绩
            {
                avgstudentsore+=c[m-1][j];
            }
            printf("%0.2lf",avgstudentsore/n);
            
            printf("
    ");
            double avgcouses[n]={0};
            for(j=0;j<n-1;j++)//每门课程的平均成绩
            {
                 avgcouse=0;
                for(i=0;i<m;i++)
                {
                   avgcouse+=c[i][j];
                }
                avgcouses[j]=avgcouse/m;
                printf("%0.2lf ",avgcouses[j]);
            }
            avgcouse=0;
            for(i=0;i<m;i++)//最后一门课程的平均成绩
            {
                 avgcouse+=c[i][n-1];
            }
            avgcouses[n-1]=avgcouse/m;
            printf("%0.2lf",avgcouses[n-1]);
            
            printf("
    ");
    
            for(i=0;i<m;i++)//求各科成绩都大于课程平均成绩的学生
                {
                    bool flag=true;
                   for(j=0;j<n;j++)
                   {
                           if(c[i][j]<avgcouses[j])
                           {
                               flag=false;
                               break;
                           }
                               
                    }
                    if(flag)
                        count++;
                }
            printf("%d",count);
          
        }
        return 0;
    
    }
     
  • 相关阅读:
    缺失的第一个正数
    tuple用法
    整数转罗马数字
    三种时间格式的转换
    不同包的调用
    正则表达式
    lgb模板
    线性回归
    时间序列的特征
    3D聚类
  • 原文地址:https://www.cnblogs.com/ping2yingshi/p/12272828.html
Copyright © 2011-2022 走看看