选择排序
选择排序 --简单选择排序
时间复杂度:O(n*n)
void selectSort(int a[], int n){
int key, tmp;
for(int i = 0; i< n; ++i) {
key = SelectMinKey(a, n,i); //选择最小的元素 key为当前找着的最小元素下标
if(key != i){ //如果第i次要查找的最小元素和当前最小元素下标key相等,则无需交换
tmp = a[i]; //最小元素与第i位置元素互换
a[i] = a[key];
a[key] = tmp;
}
}
}
选择排序 --二元选择排序
- 改进后对n个数据进行排序,最多只需进行[n/2]趟循环即可
- 第一趟找到最小的元素放到下标0的位置,最大元素放到下标n-1位置,以此类推。。。。
void SelectSort(int r[],int n) {
int i ,j , min ,max, tmp;
for (i=1 ;i <= n/2;i++) {
// 做不超过n/2趟选择排序
min = i; max = i ; //分别记录最大和最小关键字记录位置
for (j= i+1; j<= n-i; j++) {
if (r[j] > r[max]) {
max = j ; continue ;
}
if (r[j]< r[min]) {
min = j ;
}
}
//该交换操作还可分情况讨论以提高效率
tmp = r[i-1]; r[i-1] = r[min]; r[min] = tmp;
tmp = r[n-i]; r[n-i] = r[max]; r[max] = tmp;
}
}