hdu 2023 求平均成绩(c语言)

news/2024/6/19 2:19:39 标签: c/c++, java

hdu 2023 求平均成绩

点击做题网站链接

题目描述

Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)

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

题目难点

1. 开辟一个二维数组grade[ 50 ][ 5 ]存储每个学生每门课的成绩,数组最好是double型,万一出现小数好处理
2. 开辟一个stu_aver[50]数组存储每个学生的平均成绩
3. 开辟一个pro_aver[5]数组存储每门课的平均成绩

问题解答

#include <stdio.h>

int main()
{
    int m, n;//n是学生数,m是课程数
    int Count = 0;//Count:各科成绩均大于等于平均成绩的学生数量
    double grade[50][5];//grade数组:存储每个学生每门课的成绩
    double stu_aver[50];//stu_aver数组:存储每个学生的平均成绩
    double pro_aver[5];//pro_aver数组:存储每门课的平均成绩
    double stu_average, pro_average;//每个学生的和每门课的平均成绩
    
    while( scanf( "%d%d",&n,&m ) != EOF )
    {
        Count = 0;//每进行一次循环,Count就要重新初始化为0

		/*输入每个同学每门课的成绩*/
        for(int i=0; i<n; ++i)
            for(int j=0; j<m; ++j)
                scanf( "%lf", &grade[i][j] );
		
		/*算出每个同学的平均成绩,并把其存储到相应数组中*/
        for(int i=0; i<n; ++i)
        {
            stu_average = 0;//每次算新的同学都需初始化
            for(int j=0; j<m; ++j)
                stu_average += grade[i][j];//得到这位同学成绩总和
            stu_aver[i] = stu_average / (m*1.0);//得到这位同学的平均成绩并存储于数组中
        }

		/*算出每门课的平均成绩,并把其存储到相应数组中*/
        for(int j=0; j<m; ++j)
        {
            pro_average = 0;
            for(int i=0; i<n; ++i)
                pro_average += grade[i][j];
            pro_aver[j] = pro_average / (n*1.0);
        }

		/*计算各科成绩均大于等于平均成绩的学生数量*/
        for(int i=0; i<n; ++i)
        {
            int key = 1;//开关
            for(int j=0; j<m; ++j)
            {
                if( grade[i][j] < pro_aver[j] )
                    key = 0;//只要有一个不满足,开关就关上
            }
            
            if( key == 1 ) Count++;//只有开关打开的同学才能被计数
        }

		/*打印每个学生的平均成绩*/
        printf( "%.2lf", stu_aver[0] );
        for(int i=1; i<n; ++i)
            printf( " %.2lf",stu_aver[i] );
        printf( "\n" );

		/*打印每门课的平均成绩*/
        printf( "%.2lf", pro_aver[0] );
        for(int i=1; i<m; ++i)
            printf( " %.2lf", pro_aver[i] );
        printf( "\n" );
		
		/*最毒瘤的是这边要打印两个空行,不然AC不了*/
        printf( "%d\n\n", Count );
    }
    return 0;
}

转载于:https://www.cnblogs.com/yuzilan/p/10626158.html


http://www.niftyadmin.cn/n/1050071.html

相关文章

Persistence API:持久性单元(Persistence Units)

如果你打算在你的应用中使用JPA&#xff0c;你就需要使用持久性单元(Persistence Units)。持久性单元具有唯一的名称&#xff0c;负责定义应用中的一组实体如何进行管理和持久性。在应用中使用persistence .xml文件来设置持久性单元&#xff0c;可以配置多个持久性单元&#xf…

消息传递

传送门 消息传递 解题思路 一开始怎么觉得那么难&#xff0c;后来稍微一问mjt大佬怎么那么简单&#xff1f; 意思就是你选一个人进行消息传递&#xff0c;然后求最少时间。 所以每个点都有当根节点的机会&#xff0c;遍历根节点。 然后就是儿子节点的问题了&#xff0c;然后就用…

JAVA上加密算法的实现用例(转)

2001 年 7 月 04 日 通常,使用的加密算法 比较简便高效,密钥简短&#xff0c;加解密速度快&#xff0c;破译极其困难。本文介绍了 MD5/SHA1&#xff0c;DSA&#xff0c;DESede/DES&#xff0c;Diffie-Hellman的使用。 第1章基础知识 1.1. 单钥密码体制 单钥密码体…

高性能的MySQL(6)查询慢与重构查询

只有好的库表结构、合理的索引还不够&#xff0c;我们还需要合理的设计查询&#xff0c;齐头并进&#xff0c;一个不少才能充分发挥MySQL的优势。一、查询为什么会慢&#xff1f;每一个查询由一系列的子任务组成&#xff0c;每个子任务都会消耗一定的时间。这个我们在之前的单个…

JS判断客户端是IOS还是ANDROID

//判断app是ios还是androidexport function isIosorAndroid():string{let u navigator.userAgent;let isAndroid u.indexOf(Android) > -1 || u.indexOf(Adr) > -1; //判断是否是 android终端let isiOS !!u.match(/\(i[^;];( U;)? CPU.Mac OS X/); //判断是否是 ios终…

AspectJ 方式来处理 Spring 的 @Transactional 注解式事务(转)

用 AspectJ 方式来处理 Spring 的 Transactional 注解式事务 关键字: 事务处理 aspectj spring 为节省你的时间&#xff0c; 如果你你不清楚什么是Spring 、AspectJ、事务处理&#xff0c;本文就不适合你看。你可以路过就走。 在网络应用中&#xff0c;我们几乎总是需要严密控…

beanRefContext.xml

将spring配置打包写好书写beanRefContext.xmldemo<?xml version"1.0" encoding"UTF-8"?><!DOCTYPE beans PUBLIC "-//SPRING//DTD BEAN//EN" "http://www.springframework.org/dtd/spring-beans.dtd"><beans default…

C++ 的背影           --C++之父Bjarne Stroustrup印象

热爱C的朋友请不要误会&#xff0c;我并不是在暗示“C已经日薄西山”&#xff0c;或者任何类似的意思。从语义上来说&#xff0c;C作为一门编程语言&#xff0c;当然不会有什么背影。事实上&#xff0c;我想说的是一个人的背影。因此这个题目显得有点突兀&#xff0c;甚至哗众取…