c语言运行时出现程序运行错误如何解决。代码如下
#include<stdio.h>#defineARRAYSIZE10000intmain(){intsort(inta[ARRAYSIZE],intb,intc);in...
#include<stdio.h>
#define ARRAYSIZE 10000
int main()
{
int sort(int a[ARRAYSIZE],int b,int c);
int i;
int date[ARRAYSIZE]={10,20,30,40,50};
int n=5;
for(i=0;i<n;i++)
printf("%d ",date[i]);
printf("\n");
int addN;
scanf("%d",&addN);
date[ARRAYSIZE]=sort(date,n,addN);//把这里的sort(date[ARRAYSIZE],n,addN)改一下
n=n+1;
for(i=0;i<n;i++)
printf("%d ",date[i]);
return 0;
}
int sort(int a[ARRAYSIZE],int b,int c){
int x,y,temp;
a[b+1]=c;
b=b+1;
for(x=0;x<=b-1;x++)
{
for(y=0;y<b-x;y++)
if(a[y]>a[y+1])
{
temp=a[y];
a[y]=a[y=1];
a[y+1]=temp;
}
}
return (a[ARRAYSIZE]);
} 展开
#define ARRAYSIZE 10000
int main()
{
int sort(int a[ARRAYSIZE],int b,int c);
int i;
int date[ARRAYSIZE]={10,20,30,40,50};
int n=5;
for(i=0;i<n;i++)
printf("%d ",date[i]);
printf("\n");
int addN;
scanf("%d",&addN);
date[ARRAYSIZE]=sort(date,n,addN);//把这里的sort(date[ARRAYSIZE],n,addN)改一下
n=n+1;
for(i=0;i<n;i++)
printf("%d ",date[i]);
return 0;
}
int sort(int a[ARRAYSIZE],int b,int c){
int x,y,temp;
a[b+1]=c;
b=b+1;
for(x=0;x<=b-1;x++)
{
for(y=0;y<b-x;y++)
if(a[y]>a[y+1])
{
temp=a[y];
a[y]=a[y=1];
a[y+1]=temp;
}
}
return (a[ARRAYSIZE]);
} 展开
2个回答
推荐于2017-12-15
展开全部
错误地方很多
sort函数返回值就不对,不能返回数组,sort函数里面直接修干数组,不需要返回
排序冒泡法 交换数值
temp=a[y];
a[y]=a[y+1];
a[y+1]=temp;
y+1 超出范围,上面for(y=0;y<b-x;y++) 改为for(y=0;y<b-x-1;y++)
#include<stdio.h>
#define ARRAYSIZE 10000
int main()
{
int sort(int a[ARRAYSIZE],int b,int c);
int i;
int date[ARRAYSIZE]={10,20,30,40,50};
int n=5;
for(i=0;i<n;i++)
printf("%d ",date[i]);
printf("\n");
int addN;
scanf("%d",&addN);
printf("%d\n",addN);
sort(date,n,addN);
//把这里的sort(date[ARRAYSIZE],n,addN)改一下
n=n+1;
for(i=0;i<n;i++)
printf("%d ",date[i]);
return 0;
}
int sort(int a[ARRAYSIZE],int b,int c)
{
int x,y,temp;
a[b]=c;
b=b+1;
for(x=0;x<=b-1;x++)
{
for(y=0;y<b-x;y++)
if(a[y]>a[y+1])
{
temp=a[y];
a[y]=a[y+1];
a[y+1]=temp;
}
}
return 0;
}
sort函数返回值就不对,不能返回数组,sort函数里面直接修干数组,不需要返回
排序冒泡法 交换数值
temp=a[y];
a[y]=a[y+1];
a[y+1]=temp;
y+1 超出范围,上面for(y=0;y<b-x;y++) 改为for(y=0;y<b-x-1;y++)
#include<stdio.h>
#define ARRAYSIZE 10000
int main()
{
int sort(int a[ARRAYSIZE],int b,int c);
int i;
int date[ARRAYSIZE]={10,20,30,40,50};
int n=5;
for(i=0;i<n;i++)
printf("%d ",date[i]);
printf("\n");
int addN;
scanf("%d",&addN);
printf("%d\n",addN);
sort(date,n,addN);
//把这里的sort(date[ARRAYSIZE],n,addN)改一下
n=n+1;
for(i=0;i<n;i++)
printf("%d ",date[i]);
return 0;
}
int sort(int a[ARRAYSIZE],int b,int c)
{
int x,y,temp;
a[b]=c;
b=b+1;
for(x=0;x<=b-1;x++)
{
for(y=0;y<b-x;y++)
if(a[y]>a[y+1])
{
temp=a[y];
a[y]=a[y+1];
a[y+1]=temp;
}
}
return 0;
}
展开全部
错误地方很多
sort函数返回值就不对,不能返回数组,sort函数里面直接修干数组,不需要返回
排序冒泡法
交换数值
temp=a[y];
a[y]=a[y+1];
a[y+1]=temp;
y+1
超出范围,上面for(y=0;y<b-x;y++)
改为for(y=0;y<b-x-1;y++)
#include<stdio.h>
#define
ARRAYSIZE
10000
int
main()
{
int
sort(int
a[ARRAYSIZE],int
b,int
c);
int
i;
int
date[ARRAYSIZE]={10,20,30,40,50};
int
n=5;
for(i=0;i<n;i++)
printf("%d
",date[i]);
printf("\n");
int
addN;
scanf("%d",&addN);
printf("%d\n",addN);
sort(date,n,addN);
//把这里的sort(date[ARRAYSIZE],n,addN)改一下
n=n+1;
for(i=0;i<n;i++)
printf("%d
",date[i]);
return
0;
}
int
sort(int
a[ARRAYSIZE],int
b,int
c)
{
int
x,y,temp;
a[b]=c;
b=b+1;
for(x=0;x<=b-1;x++)
{
for(y=0;y<b-x;y++)
if(a[y]>a[y+1])
{
temp=a[y];
a[y]=a[y+1];
a[y+1]=temp;
}
}
return
0;
}
sort函数返回值就不对,不能返回数组,sort函数里面直接修干数组,不需要返回
排序冒泡法
交换数值
temp=a[y];
a[y]=a[y+1];
a[y+1]=temp;
y+1
超出范围,上面for(y=0;y<b-x;y++)
改为for(y=0;y<b-x-1;y++)
#include<stdio.h>
#define
ARRAYSIZE
10000
int
main()
{
int
sort(int
a[ARRAYSIZE],int
b,int
c);
int
i;
int
date[ARRAYSIZE]={10,20,30,40,50};
int
n=5;
for(i=0;i<n;i++)
printf("%d
",date[i]);
printf("\n");
int
addN;
scanf("%d",&addN);
printf("%d\n",addN);
sort(date,n,addN);
//把这里的sort(date[ARRAYSIZE],n,addN)改一下
n=n+1;
for(i=0;i<n;i++)
printf("%d
",date[i]);
return
0;
}
int
sort(int
a[ARRAYSIZE],int
b,int
c)
{
int
x,y,temp;
a[b]=c;
b=b+1;
for(x=0;x<=b-1;x++)
{
for(y=0;y<b-x;y++)
if(a[y]>a[y+1])
{
temp=a[y];
a[y]=a[y+1];
a[y+1]=temp;
}
}
return
0;
}
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询