Anonymous 发表于 2021-12-14 17:41:49

要求数组最后一个数存前4个数的平均数,所以我求平均数,排序,查找老是弄不对

本帖最后由 匿名 于 2021-12-14 18:14 编辑

#include<stdio.h>
#define N 5
float ave(float a);
void order(float a);
int ONE(float a,float b);
int main(void)
{float b;
int i,m;
float j;
printf("请输入%d个成绩:",N-1);
for(i=0;i<N-2;i++)
   scanf("%f ",&b) ;
b=ave(b);
printf("平均值为:%.1f\n",b);
order(b);
printf("成绩由大到小排列为:");
for(i=0;i<N-1;i++)
   printf("%f",b);
printf("\n请输入带查找成绩: ");
do
{ scanf("%f ",&j);
m=ONE(b,j);}
while(m==0);
printf("所查找成绩在数组中下标为:%d",m);
return 0; }

float ave(float a)
{float aver,sum=0;
int i;
for(i=0;i<N-1;i++)
   sum=sum+a;
aver=sum/(N-1);
return aver;}

void order(float a)
{int i,j;
float k;
for(i=0;i<N-1;i++)
   {for(j=0;j<N-2+i;j++)
    if(a<a)
        {k=a;a=a;a=k;}}}
       
int ONE(float a,float b)
{int low=0,high=N-2,mid,find=0;
while(low<high)
{mid=(low+high)/2;
if(b>a) high=mid-1;
else if(b<a) low=mid+1;
   else if(b==a)   
              {find=1;break;}}
if(find==1) return mid;
else{printf("\n所查找成绩不存在,请再次输入:"); return 0;}}



排序:冒泡排序
查找:折半查找

人造人 发表于 2021-12-14 18:36:11

你开心就好
页: [1]
查看完整版本: 要求数组最后一个数存前4个数的平均数,所以我求平均数,排序,查找老是弄不对