马上注册,结交更多好友,享用更多功能^_^
您需要 登录 才可以下载或查看,没有账号?立即注册
x
本帖最后由 dongmei 于 2019-7-6 17:06 编辑 int fun(int score[], int m, int below[])
{
int i,j,num=0;
double sum=0.0,aver;
for(i=0;i<m;i++)
{
sum=sum+score[i];
}
aver=(double)(sum/m);
for(i=0;i<m;i++)
if(aver>score[i])
{
num++;
below[num-1]=score[i];
}
return num;
}
int fun(int score[], int m, int below[])
{
int i,j,num=0;
double sum=0.0,aver;
for(i=0;i<m;i++)
{
sum=sum+score[i];
}
aver=(double)(sum/m);
for(i=0;i<m;i++)
{
if(aver>score[i])
num++;
below[num-1]=score[i];
}
return num;
}
这两段代码的运行结果为什么会不同?
本帖最后由 jackz007 于 2019-7-6 17:34 编辑
两个代码的主要区别如下:
代码1: if(aver > score[i]) {
num ++ ;
below[num - 1] = score[i] ;
}
代码2: if(aver > score[i]) num ++ ;
below[num - 1] = score[i] ;
两个代码输出的 num 数值应该是一样的,不一样的是数组 below[] 中所记录的内容,代码 1 会准确记录所有低于平均值的那些分数;代码 2 每次循环都会把 score[ i ] 记录到 below[num - 1],而无论这个分数是否低于平均值。所以,below[num - 1] 中所保存的实际上是 num 被改变前的最后一个 score[ i ] 值,这显然不是我们的预期。所以,很显然,代码 2 是错误的。
|