鱼C论坛

 找回密码
 立即注册
查看: 2710|回复: 3

怎么修改才可以运行啊 错哪了??

[复制链接]
发表于 2018-11-25 09:26:19 | 显示全部楼层 |阅读模式

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

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

x

题目:在主函数中定义一维数组int array[10],自定义以下函数:输入数组元素,输出数组元素、求数组元素平均值、输出数组元素最大值、输出数组元素最小值、查找某数值元素是否存在(若存在,请输出下标)、给数组元素排序,要求在主函数中对各子函数进行调用和测试。


#include<stdio.h>
void input(int*,int*);
void output(int array[],int n);
void find(int array[],int n);
void sort(int array[],int n);
int maxnum(int array[],int n);
int minnum(int array[],int n);
double ave(int array[],int n);
int main()
{
        int array[10],n,x,y;
        double z;
        scanf("%d",&n);
  output(array,n);
x=maxnum(array,n);
  y=minnum(array,n);
z=ave(array,n);
find(array,n);
  sort(array,n);
  return 0;
}
void input(int *array,int *n)
{
        int i;/*n为实际输入个数*/
        for(i=0;i<=*n;i++)
        {
        scanf("%d",&array[i]);
       
    }
        return;
}
void output(int array[],int n)
{
        int i;
        for(i=0;i<=n;i++)
        printf(" %d",array[i]);
        printf("\n");
        return;
}
double ave(int array[],int n)
{
        int sum=0,i;
        double ave;
        for(i=0;i<n;i++)
        {
                sum+=array[i];
        }
        printf("average is %lf\n",ave=(double)sum/n);
        return ave;
}
int maxnum(int array[],int n)
{
        int i,max;
        max=array[0];
        for(i=1;i<n;i++)
                {if(array[i]>max)
                        {
                                max=array[i];
                }
        }
        printf("max is %d\n",max);
        return max;
}
int minnum(int array[],int n)
{
int i,min;
        min=array[0];
        for(i=1;i<n;i++)
                {
                        if(array[i]<min)
                        {min=array[i];
                        }
        }
        printf("min is %d\n",min);
        return min;
}
void find(int array[],int n)
{
int i,x,t=0;
printf("请输入查找值:\n");
scanf("%d",&x);
for(i=0;i<n;i++)
{
         if(x==array[i])
         {printf("下标为%d\n",i);
         t++;
         }
         if(t==0)
         {printf("无法查到\n");
         }
         return;
}
}
void sort(int array[],int n)
{
          int m,i,j;
          for(i=0;i<n-1;i++)
          {for(j=1;j<n-1;j++)
          {if(array[j]>array[j+1])
          {m=array[j];
          array[j]=array[j+1];
          array[j+1]=m;
          }
          }
          }
          printf("从小到大排序为:");
          for(i=0;i<n-1;i++)
                  printf(" %d",array[i]);
          return;
}
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2018-11-26 09:25:46 | 显示全部楼层
你这个 有滴  基本语法都错了  还有一些 数组的小细节也有问题  参数 传值 还得再好好 学学
对了  你排序写的啥意思 我没看懂    我给你 改成 冒泡排序了  你看一下    有些地方也改了 你看看 行不行
  1. /*在主函数中定义一维数组int array[10],自定义以下函数:输入数组元素,
  2. 输出数组元素、
  3. 求数组元素平均值、
  4. 输出数组元素最大值、
  5. 输出数组元素最小值、
  6. 查找某数值元素是否存在(若存在,请输出下标)、
  7. 给数组元素排序,要求在主函数中对各子函数进行调用和测试。*/

  8. #include<stdio.h>
  9. void input(int *array,int n);
  10. void output(int array[],int n);
  11. void find(int array[],int n);
  12. void sort(int array[],int n);
  13. int maxnum(int array[],int n);
  14. int minnum(int array[],int n);
  15. double ave(int array[],int n);
  16. int main()
  17. {
  18.         int array[10],n,x,y;
  19.         double z;
  20.         scanf("%d",&n);

  21.         input (array,n);

  22.         output(array,n);

  23.         x=maxnum(array,n);

  24.         y=minnum(array,n);

  25.         z=ave(array,n);

  26.         find(array,n);

  27.         sort(array,n);
  28.        
  29.                
  30.         return 0;
  31. }
  32. void input(int *array,int n)
  33. {
  34.         int i;/*n为实际输入个数*/
  35.         for(i=0;i < n;i++)
  36.         {
  37.         scanf("%d",&array[i]);
  38.     }
  39.         return;
  40. }
  41. void output(int array[],int n)
  42. {
  43.         int i;
  44.         for(i=0; i < n;i++)
  45.         printf("%d ",array[i]);
  46.         printf("\n");
  47.         return;
  48. }
  49. double ave(int array[],int n)
  50. {
  51.         int sum=0,i;
  52.         double ave;
  53.         for(i=0;i<n;i++)
  54.         {
  55.                 sum+=array[i];
  56.         }
  57.         printf("average is %lf\n",ave=(double)sum/n);
  58.         return ave;
  59. }
  60. int maxnum(int array[],int n)
  61. {
  62.         int i,max;
  63.         max=array[0];
  64.         for(i=1;i<n;i++)
  65.         {if(array[i]>max)
  66.         {
  67.                 max=array[i];
  68.         }
  69.         }
  70.         printf("max is %d\n",max);
  71.         return max;
  72. }
  73. int minnum(int array[],int n)
  74. {
  75.         int i,min;
  76.         min=array[0];
  77.         for(i=1;i<n;i++)
  78.         {
  79.                 if(array[i]<min)
  80.                 {min=array[i];
  81.                 }
  82.         }
  83.         printf("min is %d\n",min);
  84.         return min;
  85. }
  86. void find(int array[],int n)
  87. {
  88.         int i,x,t=0;
  89.         printf("请输入查找值: ");
  90.         scanf("%d",&x);
  91.         for(i=0;i<n;i++)
  92.         {
  93.                 if(array[i] == x)
  94.                 {
  95.                                 t = i;                                               
  96.                                 printf("数组下标为%d\n",t);       
  97.                                 break;
  98.                 }                                       
  99.         }
  100.         if(array[i] != x)
  101.                 printf("无法查到\n");
  102.                
  103. }
  104. void sort(int array[],int n)
  105. {
  106.         int i,j;
  107.         int temp;
  108.         for(i = 0; i < n; i++)
  109.         {
  110.                 for(j = 0; j <n-1-i; j++)
  111.                 {
  112.                         if(array[j] > array[j+1])
  113.                         {
  114.                                 temp = array[j];
  115.                                 array[j] = array[j+1];
  116.                                 array[j+1] = temp;
  117.                         }
  118.                 }
  119.                
  120.         }

  121.         printf("从小到大排序为:");
  122.         for(i=0;i<n;i++)
  123.                 printf(" %d",array[i]);
  124.         putchar('\n');
  125.         return;
  126. }
复制代码
6.png
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2018-11-26 16:29:01 | 显示全部楼层
西瓜小刚 发表于 2018-11-26 09:25
你这个 有滴  基本语法都错了  还有一些 数组的小细节也有问题  参数 传值 还得再好好 学学
对了  你排序 ...

谢谢大佬!!但是好像运行不出来
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2018-11-26 16:30:38 | 显示全部楼层
triviumgo 发表于 2018-11-26 16:29
谢谢大佬!!但是好像运行不出来

啊啊啊可以
谢谢
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-6-12 21:31

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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