数组排序求解答
main(){
int i,j,p,q,s,n,a[11]={127,3,6,28,54,68,87,105,162,18};
for(i=0;i<10;i++)
{ p=i;q=a[i];
for(j=i+1;j<10;j++)
if(q<a[j]) {p=j;q=a[j];}
if(p!=i)
{
s=a[i];
a[i]=a[p];
a[p]=s;
}
printf("%d ",a[i]);
}
printf("\ninput number:\n");
scanf("%d",&n);
for(i=0;i<10;i++)
if(n>a[i])
{for(s=9;s>=i;s--) a[s+1]=a[s];
break;}
a[i]=n;
for(i=0;i<=10;i++)
printf("%d ",a[i]);
printf("\n");
}
这是段在已排好序的数组里插入一位数后,数组仍然有序的程序。
哪位帮解释下这段代码的作用(红色部分),
我的理解是排好序后的数组让新的a[i]与a[p]能对上位,不知道这样理解对不,但是我不知道为什么这样写。
哪位帮解答下,稍微详细点- - 谢谢