鱼C论坛

 找回密码
 立即注册
查看: 1089|回复: 1

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

[复制链接]
匿名鱼油
匿名鱼油  发表于 2021-12-14 17:41:49 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
本帖最后由 匿名 于 2021-12-14 18:14 编辑
  1. #include<stdio.h>
  2. #define N 5
  3. float ave(float a[N]);
  4. void order(float a[N]);
  5. int ONE(float a[N],float b);
  6. int main(void)
  7. {float b[N];
  8. int i,m;
  9. float j;
  10. printf("请输入%d个成绩:",N-1);
  11. for(i=0;i<N-2;i++)
  12.    scanf("%f ",&b[i]) ;
  13. b[N-1]=ave(b);
  14. printf("平均值为:%.1f\n",b[N-1]);
  15. order(b);
  16. printf("成绩由大到小排列为:");
  17. for(i=0;i<N-1;i++)
  18.    printf("%f  ",b[i]);
  19. printf("\n请输入带查找成绩: ");
  20. do
  21. { scanf("%f ",&j);
  22.   m=ONE(b[N],j);}
  23. while(m==0);
  24. printf("所查找成绩在数组中下标为:%d",m);
  25. return 0; }

  26. float ave(float a[N])
  27. {float aver,sum=0;
  28. int i;
  29. for(i=0;i<N-1;i++)
  30.    sum=sum+a[i];
  31. aver=sum/(N-1);
  32. return aver;}

  33. void order(float a[N])
  34. {int i,j;
  35. float k;
  36. for(i=0;i<N-1;i++)
  37.    {for(j=0;j<N-2+i;j++)
  38.     if(a[j]<a[j+1])
  39.         {k=a[j];a[j]=a[j+1];a[j+1]=k;}}}
  40.        
  41. int ONE(float a[N],float b)
  42. {int low=0,high=N-2,mid,find=0;
  43. while(low<high)
  44. {mid=(low+high)/2;
  45. if(b>a[mid]) high=mid-1;
  46. else if(b<a[mid]) low=mid+1;
  47.      else if(b==a[mid])     
  48.               {find=1;break;}}
  49. if(find==1) return mid;
  50. else{printf("\n所查找成绩不存在,请再次输入:"); return 0;}}
复制代码




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

使用道具 举报

发表于 2021-12-14 18:36:11 | 显示全部楼层
你开心就好
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-4-25 13:40

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表