指针气泡法双向排序 a[0]的值不对
这程序排序以后a[0]的值是1288。变成了1288,2,3,4,5,6,7,8,9,10列位帮我看下什么地方的值取错了?谢谢啦。
#include <stdio.h>
main()
{
int i,n,a[]={10,9,8,7,6,5,4,3,2,1};
printf("\nthe sorted array is:\n");
n=sizeof(a)/2;
inv(a,n);
for(i=0;i<n;i++)
printf("%d,",a[i]);
}
inv(x,y)
int *x,y;
{
int i,h=0,temp,*pj,*pk;
for(i=0;i<y;i++)
{
for(pj=x+y-1;pj>x+i;pj--)
if(*pj<*(pj-1)) {temp=*pj;*pj=*(pj-1);*(pj-1)=temp;h++;}
for(pk=pj;pk<x+y-h;pk++)
if(*pk<*(pk-1)) {temp=*pk;*pk=*(pk-1);*(pk-1)=temp;}
}
}
[ 本帖最后由 人莫予毒 于 2010-12-26 17:05 编辑 ]