数组指针对于数组排序优化写法的疑问

[复制链接]
1862|1
 楼主| chenqinte 发表于 2013-9-22 16:24 | 显示全部楼层 |阅读模式
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;

}





 楼主| chenqinte 发表于 2013-9-22 16:34 | 显示全部楼层
X指针变量的发生变化,意味着*X对应的数组数据发生变化,主函数条用后,a[10]数组的排序发生改变。
后来自己按照这么想想通了,不知道理解的对不对?
您需要登录后才可以回帖 登录 | 注册

本版积分规则

53

主题

165

帖子

0

粉丝
快速回复 在线客服 返回列表 返回顶部