选择排序的一个程序,有点问题。
这个程序,编译通过,可是执行有问题,我用VC6.0看过了,调用那个sort函数得时候 进去J=3116,K=19,没有找到问题,求教。/*****************************************************************
** HighlightCodeV3.1 software by yzfy(雨中飞燕) http:// **
*****************************************************************/
#include <stdio.h>
int sort(int x[],int n)
{
int i,j,k,t;
for(i=0;i<n-1;i++)
{
k=i;
for(j=i+1;i<n;j++)
if(x[j]>x[k])
k=j;
if(k!=i)
{
t=x[i];
x[i]=x[k];
x[k]=t;
}
}
return 0;
}
int main()
{
int *p,i,a[10]={3,7,9,11,0,6,7,5,4,2};
printf("The original array:\n");
for(i=0;i<10;i++)
printf("%d",a[i]);
printf("\n");
p=a;
sort(p,10);
printf("The array has been inverted:\n");
for(p=a,i=0;i<10;i++)
{
printf("%d",*p++);
}
printf("\n");
return 0;
}
** HighlightCodeV3.1 software by yzfy(雨中飞燕) http:// **
*****************************************************************/
#include <stdio.h>
int sort(int x[],int n)
{
int i,j,k,t;
for(i=0;i<n-1;i++)
{
k=i;
for(j=i+1;i<n;j++)
if(x[j]>x[k])
k=j;
if(k!=i)
{
t=x[i];
x[i]=x[k];
x[k]=t;
}
}
return 0;
}
int main()
{
int *p,i,a[10]={3,7,9,11,0,6,7,5,4,2};
printf("The original array:\n");
for(i=0;i<10;i++)
printf("%d",a[i]);
printf("\n");
p=a;
sort(p,10);
printf("The array has been inverted:\n");
for(p=a,i=0;i<10;i++)
{
printf("%d",*p++);
}
printf("\n");
return 0;
}