#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));
}
方差始终为0且每个学生成绩不输出?
- 写回答
- 好问题 0 提建议
- 追加酬金
- 关注问题
- 邀请回答
-
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)); }
本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 无用评论 打赏 举报
悬赏问题
- ¥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门禁成品上增加查询记录功能