杂化轨道VSEPR 2021-07-24 15:44 采纳率: 93.3%
浏览 27
已结题

方差始终为0且每个学生成绩不输出?


#include<stdio.h>
#define N 5
#define M 5
float score[N][M];
float a_stu[N],a_cour[M];
int r,c;
int main( )
{
    int i,j;
    float h;
    float s_var(void);
    float highest( );
    void input_stu(void);
    void aver_stu(void);
    void aver_cour(void);
    input_stu();
    aver_stu();
    aver_cour();
    printf("\n cour1        cour2            cour3            cour4            cour5           aver\n");
    for(i=0;i<N;i++)

     { printf("\n NO %2d",i+1);
       for(j<=0;j<M;j++)
            printf("%5.2f",score[i][j]);
        printf("%5.2f\n",a_stu[i]);  
     }
    printf("\naverage");
    for(j=0;j<M;j++)
        printf("%8.2f",a_cour[j]);
    printf("\n");
    h=highest( );
    printf("higest is %7.2f NO%2d courese %2d\n",h,r,c);
    printf("variance is %7.2f\n",s_var( ));
    return 0;

}
void input_stu(void)
{
    int i,j;
    for(i=0;i<N;i++)
        {
            printf("NO.%2d student score : ",i+1);
            for(j=0;j<N;j++)
                scanf("%f",&score[i][j]);
        }
}
void aver_stu(void)
{
    int i,j;
    float s;
    for(i=0;i<N;i++)
        for(j=0,s=0;j<M;j++)
            s+=score[i][j];
        a_stu[i]=s/5.0;//给每名学生的个人平均成绩
}
void aver_cour(void)//每个课程的学生学习成绩
{
    int i,j;
    float s;
    for(j=0;j<M;j++)
        {
            s=0;
            for(i=0;i<N;i++)
                s+=score[i][j];
            a_cour[j]=s/(float)N;
        }
}
float highest( )
{
    float high;
    int i,j;
    high=score[0][0];
    for(i=0;i<N;i++)
        for(j=0;j<M;j++)
            if(score[i][j]>high)
                {
                    high=score[i][j];
                    r=i+1;
                    c=j+1;
                }
                return (high);
}
float s_var(void)//这里开始求方差了
{
    int i;
    float sumx,sumxn;
    sumx=0.0;
    sumxn=0.0;
    for(i=0;i<N;i++)
       {
           sumx+a_stu[i]*a_stu[i];
           sumxn+=a_stu[i];
       }
       return(sumx/N-(sumxn/N)*(sumxn/N));
}
  • 写回答

2条回答 默认 最新

  • 浪客 2021-07-24 16:33
    关注

    修改地方用//注释了

     
    #include<stdio.h>
    #define N 5
    #define M 5
    float score[N][M];
    float a_stu[N],a_cour[M];
    int r,c;
    int main( )
    {
        int i,j;
        float h;
        float s_var(void);
        float highest( );
        void input_stu(void);
        void aver_stu(void);
        void aver_cour(void);
        input_stu();
        aver_stu();
        aver_cour();
        printf("\n cour1        cour2            cour3            cour4            cour5           aver\n");
        for(i=0;i<N;i++)
         { printf("\n NO %2d ",i+1);
           for(j=0;j<M;j++)//for(j<=0;j<M;j++)
                printf("%5.2f ",score[i][j]);
            printf("%5.2f\n",a_stu[i]);  
         }
        printf("\naverage");
        for(j=0;j<M;j++)
            printf("%8.2f ",a_cour[j]);
        printf("\n");
        h=highest( );
        printf("higest is %7.2f NO%2d courese %2d\n",h,r,c);
        printf("variance is %7.2f\n",s_var( ));
        return 0;
    }
    void input_stu(void)
    {
        int i,j;
        for(i=0;i<N;i++)
            {
                printf("NO.%2d student score : ",i+1);
                for(j=0;j<N;j++)
                    scanf("%f",&score[i][j]);
            }
    }
    void aver_stu(void)
    {
        int i,j;
        float s;
        for(i=0;i<N;i++)
        {//
            s=0;//
            for(j=0,s=0;j<M;j++)
                s+=score[i][j];
            a_stu[i]=s/5.0;//给每名学生的个人平均成绩
        }//
    }
    void aver_cour(void)//每个课程的学生学习成绩
    {
        int i,j;
        float s;
        for(j=0;j<M;j++)
            {
                s=0;
                for(i=0;i<N;i++)
                    s+=score[i][j];
                a_cour[j]=s/(float)N;
            }
    }
    float highest( )
    {
        float high;
        int i,j;
        high=score[0][0];
        for(i=0;i<N;i++)
            for(j=0;j<M;j++)
                if(score[i][j]>high)
                    {
                        high=score[i][j];
                        r=i+1;
                        c=j+1;
                    }
                    return (high);
    }
    float s_var(void)//这里开始求方差了
    {
        int i;
        float sumx,sumxn;
        sumx=0.0;
        sumxn=0.0;
        for(i=0;i<N;i++)
           {
               sumx+=a_stu[i]*a_stu[i];//sumx+a_stu[i]*a_stu[i];
               sumxn+=a_stu[i];
           }
           return(sumx/N-(sumxn/N)*(sumxn/N));
    }
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

问题事件

  • 系统已结题 8月2日
  • 已采纳回答 7月25日
  • 创建了问题 7月24日

悬赏问题

  • ¥15 seatunnel-web使用SQL组件时候后台报错,无法找到表格
  • ¥15 fpga自动售货机数码管(相关搜索:数字时钟)
  • ¥15 用前端向数据库插入数据,通过debug发现数据能走到后端,但是放行之后就会提示错误
  • ¥30 3天&7天&&15天&销量如何统计同一行
  • ¥30 帮我写一段可以读取LD2450数据并计算距离的Arduino代码
  • ¥15 飞机曲面部件如机翼,壁板等具体的孔位模型
  • ¥15 vs2019中数据导出问题
  • ¥20 云服务Linux系统TCP-MSS值修改?
  • ¥20 关于#单片机#的问题:项目:使用模拟iic与ov2640通讯环境:F407问题:读取的ID号总是0xff,自己调了调发现在读从机数据时,SDA线上并未有信号变化(语言-c语言)
  • ¥20 怎么在stm32门禁成品上增加查询记录功能