int inv(int *x,int n)
{ i,j,m,t;
m=(n-1)/2;
for(i=0;i<=m;i++)
{
j=n-1-i;
t=*(x+i);
*(x+i)=*(x+j);
*(x+j)=t;
}
}
main()
{int a[10],int i;
输入a[10];
inv (a,10);
输出a;
}
改写法通过指针(变量地址)改变数组的排列。
优化写法如下:
int inv(int *x,int n)
{ int *i =x,*j=x+n-1,t;
for(;i<j;i++,j--)
{
t =*i;--------以我的理解x指针变量存放的数据为数组的地址
*i =*j;--------该交换只是修改了x指针变量存放数组地址的循序
*j = t;--------该函数能实现数组数据的重新排列吗????初学C!!
}
}
main()
{int a[10],int i;
输入a[10];
inv (a,10);
输出a;
}
|