这个C代码给了我一些不可预知的结果。该程序旨在收集6个并打印出最大值,最大值和平均值的位置。它应该只有3个函数 - 输入,max_avr_pos和输出,用于执行代码应该执行的操作但是我得到了不可预测的结果。请问可能是什么问题
#include <stdio.h>
#include <stdlib.h>
#include <conio.h>
void input_vals(int arrnum[]);
void max_ave_val(int arrnum1[],double *average,int *maxval,int *position);
void print_output(double *average1,int *maxval1,int *position1);
int main(void) {
int arrnum[6],maxval2,position2;
double average2;
input_vals(arrnum);
max_ave_val(arrnum,&average2,&maxval2,&position2);
print_output(&average2,&maxval2,&position2);
_getche();
return 0;
}
void input_vals(int arrnum[]){
int count;
printf("\n Please enter six numbers\n");
for(count=0;count<6;count++) {
scanf("%d",&arrnum[count]);
}
}
void max_ave_val(int arrnum1[],double *average,int *maxval,int *position) {
int total=0;
int cnt,cnt1,cnt2,limit,maxval2,post;
limit=6;
/* finding the max value*/
for(cnt=0;cnt<limit-1;cnt++)
for(cnt1=limit-1;cnt1>cnt;--cnt1) {
if(arrnum1[cnt1-1]>arrnum1[cnt1]) {
maxval2=arrnum1[cnt-1];
post=(cnt-1)+1;
}
else {
maxval2=arrnum1[cnt1];
post=cnt1+1;
}
}
*maxval=maxval2;
*position=post;
/* solving for total */
for(cnt2=0;cnt2<limit;cnt2++);
{
total=total+arrnum1[cnt2];
}
*average=total/limit;
}
void print_output(double *average1,int *maxval1,int *position1) {
printf("\n value of the highest of the numbers is %d\n",*maxval1);
printf("\n the average of all the numbers is %g\n",*average1);
printf("\n the postion of the highest number in the list is %d\n",*position1);
}
答案 0 :(得分:1)
for(cnt2=0;cnt2<limit;cnt2++);
{
total=total+arrnum1[cnt2];
}
在for循环结束时 ;
。
答案 1 :(得分:1)
循环一次并将所有数字相加并检查当前最大值与当前数字。
for (cnt = 0; cnt < limit; cnt++) {
total += arrnum[cnt];
if (maxval < arrnum[cnt]) {
maxval = arrnum[cnt];
position = cnt;
}
}
maxval应初始化为limit.h的最小int值
答案 2 :(得分:0)
似乎你可以更轻松地找到最大值。怎么样:
maxval2 = -1;
post = -1;
for(cnt=0;cnt<limit-1;cnt++)
{
if(arrnum1[cnt] > maxval2)
{
post = cnt;
maxval2 = arrnum1[cnt];
}
}
答案 3 :(得分:0)
现在我写了这个盲人,但希望这似乎有所帮助,似乎不会冒犯,问题中提供的代码有点过于复杂。
void max_ave_val(int arrnum1[],double *average,int *maxval,int *position) {
#define LIMIT 6
*maxval = 0;
*average = 0.0f;
for ( Int index = 0; index < LIMIT; index++ )
{
*average += arrnum1[ index ];
if ( arrnum1[ index ] > *maxval )
{
*maxval = arrnum1[ index ];
*position = index;
}
}
*average /= LIMIT;
}
非常感谢 - 尼尔