[英]Help with bugs in a C code
这段C代码给了我一些不可预测的结果。 该程序旨在收集6个no,并打印出最大,最大no的位置和平均值。 它应该只有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);
}
for(cnt2=0;cnt2<limit;cnt2++);
{
total=total+arrnum1[cnt2];
}
;
在for循环结束时。
循环浏览一次并求和所有数字,并根据当前数字检查当前的maxval。
for (cnt = 0; cnt < limit; cnt++) {
total += arrnum[cnt];
if (maxval < arrnum[cnt]) {
maxval = arrnum[cnt];
position = cnt;
}
}
应该将maxval初始化为limit.h中的最小int值
好像您可以轻松找到最大值。 怎么样:
maxval2 = -1;
post = -1;
for(cnt=0;cnt<limit-1;cnt++)
{
if(arrnum1[cnt] > maxval2)
{
post = cnt;
maxval2 = arrnum1[cnt];
}
}
现在,我已经编写了这个盲文,但是希望这对您有所帮助,似乎,不要冒犯,问题中补充的代码有些复杂。
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;
}
非常感谢-尼尔
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.