• hdu2023


    求平均成绩

    Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)
    Total Submission(s): 45109    Accepted Submission(s): 10708

    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
     
    这道题看懂题意后不难。注意不要直接暴力模拟,据说会超时。总之小细节比较烦人。PE了n次。还有注意一些写代码的习惯,在PE后如何检查代码的习惯。
    #include<stdio.h>
    int main()
    {
    	int n,m;
    	while(scanf("%d%d",&n,&m)!=EOF)
    	{
    		int i,j,sum=0,t,flag=1;
    		double a[100][100],sn[50]={0},sm[5]={0};
    		for(i=0;i<n;i++)
    		{
    			for(j=0;j<m;j++)
    			{
    				scanf("%lf",&a[i][j]);
    				sn[i]+=a[i][j];
    				sm[j]+=a[i][j];
    			}
    		}
    		for(i=0;i<n;i++){
    			if(flag)
    			{printf("%.2lf",sn[i],sn[i]/=m);
    			flag=0;}
    			else
    			printf(" %.2lf",sn[i],sn[i]/=m);
    		}
    		printf("\n");
    		for(i=0;i<m;i++){
    		if(!flag)
    			{printf("%.2lf",sm[i],sm[i]/=n);
    			flag=1;}
    			else
    			printf(" %.2lf",sm[i],sm[i]/=n);
    	}
    		printf("\n");
    		for(i=0;i<n;i++)
    		{   t=0;
    			for(j=0;j<m;j++)
    			{
    				if(a[i][j]>=sm[j])
    					t++;
    				else
    					break;
    			}
    			if(t==m)
    				sum++;
    		}
    		printf("%d\n\n",sum);
    	}
    	return 0;
    }

  • 相关阅读:
    InfinityHook原理
    段描述符
    从零到一k8s(十)ipv4,ipv6 双网卡部署k8s
    python自动化测试工具selenium使用指南
    elementui去掉弹框的黑色罩子
    linuxjenkins安装
    pythonlogging模块记录日志
    redisredis.exceptions.ResponseError: MISCONF Redis is configured to save RDB snap
    shell将文件上传至ftp
    git记录文档
  • 原文地址:https://www.cnblogs.com/unclejelly/p/4082180.html
Copyright © 2020-2023  润新知