鱼C论坛

 找回密码
 立即注册
查看: 2262|回复: 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;
}
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

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

#include<stdio.h>
void input(int *array,int n);
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);

        input (array,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("请输入查找值: ");
        scanf("%d",&x);
        for(i=0;i<n;i++)
        {
                if(array[i] == x)
                {
                                t = i;                                                
                                printf("数组下标为%d\n",t);        
                                break;
                }                                        
        }
        if(array[i] != x)
                printf("无法查到\n");
                
}
void sort(int array[],int n)
{
        int i,j;
        int temp;
        for(i = 0; i < n; i++)
        {
                for(j = 0; j <n-1-i; j++)
                {
                        if(array[j] > array[j+1])
                        {
                                temp = array[j];
                                array[j] = array[j+1];
                                array[j+1] = temp;
                        }
                }
                
        }

        printf("从小到大排序为:");
        for(i=0;i<n;i++)
                printf(" %d",array[i]);
        putchar('\n');
        return;
}
6.png
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

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

谢谢大佬!!但是好像运行不出来
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

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

啊啊啊可以
谢谢
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-10-3 00:23

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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