选择排序的基本方法是:每步将待排序记录中选出最小的纪录,顺序放在已排序的记录序列后面,直到全部排完。
在算法实现时,每一趟确定最小元素的时候会通过不断地比较交换来使得首位置为当前最小,交换是个比较耗时的操作。其实我们很容易发现,在还未完全确定当前最小元素之前,这些交换都是无意义的。我们可以通过设置一个变量min,每一次比较仅存储较小元素的数组下标,当轮循环结束之后,那这个变量存储的就是当前最小元素的下标,此时再执行交换操作即可。代码实现很简单,一起来看下。
void selectSort(int a[],int n) {
int i, j, min,temp;
for ( i = 0; i < n; i++)
{
min = i;
for (j=i+1 ; j < n; j++)
{
if (a[j]<a[min])
{
min = j;
}
}
if (min!=i)
{
temp = a[i];
a[i] = a[min];
a[min] = temp;
}
}
//output(a, n);测试用的
}
简单选择排序通过上面优化之后,无论数组原始排列如何,比较次数是不变的;对于交换操作,在最好情况下也就是数组完全有序的时候,无需任何交换移动,在最差情况下,也就是数组倒序的时候,交换次数为n-1次。综合下来,时间复杂度为O(n2)