#include
void main()
{
int i, j;
int min;
int pos;
int arr[10];
for (i = 0; i < 10; i++)
{
printf("arr[%d]=", i);
scanf("%d", &arr[i]);
}
for (i = 0; i < 9; i++)
{
min = arr[i];
pos = i;
for (j = i+1; j < 10; j++)
{
if (arr[j] //为什么这个判断不能改成arr[j]
{
min = arr[j];
pos = j;
}
}
arr[pos] = arr[i];
arr[i] =min;
}
printf("经过选择排列后的数字为:\n");
for (i = 0; i < 10; i++)
{
printf("%d\t", arr[i]);
if (i == 4)
printf("\n");
}
}
为什么这个数字排列,一旦改我上面的判断就不行,为什么不能直接arr[i],非要一个中间变量min来代替
是不一样的。那里应该是一直循环找到列表的最小值。以i=0为例,从第一项开始,找到了比它小的数,就更新min,所以才写作arr[j] < min,以找到最小的值;如果写作arr[j]<arr[i],那么只要存在比第一项小的数,就会更新min——比如,如果第一项为3,而第二项为1(更新了min),但是第三项为2,2<3,又更新了min,并不是最小的数,就会产生错误。