题目内容:
下列给定的程序中,函数proc()的功能是:用选择法对数组中的m个元素按从小到大的顺序进行排序。
例如,排序前的数据为:11 32 -5 2 1 4
则排序后的数据为:-5 2 11 14 32
请修改程序中的错误,使它能得到正确结果。
注意:不要改动main()函数,不得增行或删行,也不得更改程序的结构。
试题程序:
#include<stdi0.h>
#define M 20
void proc(int a口,int n)
{
int i,j,t,P;
//****found****
for(j=0;j<n-l;j++);
{
p=j;
for(i=j;i<n;i++)
if(a[i]<a[p])
p=i;
t=a[p];
a[p]=a[j3;
//****found****
a[p]=t:
}
}
void main()
{
int arr[M]={11,;2,-5,2,14),i,m=5;
print/("排序前的数据:");
for(i=0;i<m;i++)
printf("%d",arr[i]);
printf("\n");
proc(arr,m);
printf("排序后的顺序:");
for(i=0;i<m;i++)
printf("%d",arr[i]);
printf("\n");
}
参考答案:
答案解析: