算法_简单选择排序
每一轮选一个最小的和最靠前的位置交换。
栗子 : 3 7 1 5
第一轮:1 7 3 5
第二轮:1 3 7 5
第三轮:1 3 5 7
for(int i = 0;i<n;i++){//这里应该可以是i<n-1,最后一轮只剩一个无所谓
k = i;
for (int j = i + 1; j < n; j++) {
if (a[k] > a[j]) {
k = j;
}
}
if (k != i) {
temp = a[i];
a[i] = a[k];
a[k] = temp;
}
}
简单选择排序进化 ------>二元选择排序
一轮选择一个最小值------>一轮选择一个最大值一个最小值
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;
}
}

浙公网安备 33010602011771号