用函数(要求形实参均用指针变量传递数组的地址)对一个一维数组进行排序,数组输入,输出
voidmain(){inta[N],i;for(i=0;i<N-1;i++)cin>>a[i];sort(a,N);for(i=0;i<N-1;i++)cout<<a[...
void main()
{
int a[N],i;
for(i=0;i<N-1;i++)
cin>>a[i];
sort(a,N);
for(i=0;i<N-1;i++)
cout<<a[N]<<endl;
}
void sort (int *pn,int n)
{ int a[N],i,j,t,*p;
p=a;
for(i=0;i<N-1;i++)
{ for(j=i+1;j<=N;j++)
{ if(*(p+i)<*(p+j))
{
t=*(p+i);
*(p+i)=*(p+j);
*(p+j)=t;
}
}
}
}
不知道哪里错了 展开
{
int a[N],i;
for(i=0;i<N-1;i++)
cin>>a[i];
sort(a,N);
for(i=0;i<N-1;i++)
cout<<a[N]<<endl;
}
void sort (int *pn,int n)
{ int a[N],i,j,t,*p;
p=a;
for(i=0;i<N-1;i++)
{ for(j=i+1;j<=N;j++)
{ if(*(p+i)<*(p+j))
{
t=*(p+i);
*(p+i)=*(p+j);
*(p+j)=t;
}
}
}
}
不知道哪里错了 展开
2个回答
展开全部
N是多少?没有定义!
void sort (int *pn,int n){
int i,j,t,*p;//这里错了
p=pn;//这里错了
for(i=0;i<N;i++)//这里错了
{for(j=i+1;j<N;j++)//这里错了
{if(*(p+i)<*(p+j))
{ t=*(p+i);
*(p+i)=*(p+j);
*(p+j)=t;
}
}
}
}
void main(){
int a[N],i;
for(i=0;i<N;i++)//这里错了
cin>>a[i];
sort(a,N);
for(i=0;i<N;i++)//这里错了
cout<<a[i]<<endl;//这里错了
}
注出的地方你对照看……
追问
下面那些是帮我改过的吗?其实我并不懂啊,要怎么改
追答
那不是已经改了吗?让你对照看啊……
展开全部
#include <stdio.h>
void sort(int*a , int len)
{
int i,j,temp;
for(i=0; i<len; i++)
{
for(j=0; j<len-i-1;j++)
{
if(a[j]>a[j+1])
{
temp = a[j] ;
a[j] = a[j+1];
a[j+1] = temp;
}
}
}
}
void Print(int* a, int len)
{
int i;
for(i=0; i<len;i++)
{
printf("%d ",a[i]);
}
}
int main()
{
int a[] = {12,35,62,451,265,352,8,23,58,100};
int len = sizeof(a)/sizeof(int);
sort(a,len);
Print(a,len);
puts("");
return 0;
}
参照下我写的着个吧。
void sort(int*a , int len)
{
int i,j,temp;
for(i=0; i<len; i++)
{
for(j=0; j<len-i-1;j++)
{
if(a[j]>a[j+1])
{
temp = a[j] ;
a[j] = a[j+1];
a[j+1] = temp;
}
}
}
}
void Print(int* a, int len)
{
int i;
for(i=0; i<len;i++)
{
printf("%d ",a[i]);
}
}
int main()
{
int a[] = {12,35,62,451,265,352,8,23,58,100};
int len = sizeof(a)/sizeof(int);
sort(a,len);
Print(a,len);
puts("");
return 0;
}
参照下我写的着个吧。
更多追问追答
追问
其实我才刚学,你的是什么方法,我们要求用指针来写。
追答
那个sort函数的参数就是指针呀。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询