算法_简单选择排序

Posted Lyxin_c

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了算法_简单选择排序相关的知识,希望对你有一定的参考价值。

每一轮选一个最小的和最靠前的位置交换。

栗子 : 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;   
  
    }   
}  

 

以上是关于算法_简单选择排序的主要内容,如果未能解决你的问题,请参考以下文章

排序算法-简单选择排序

算法_简单选择排序

各种基本算法实现小结—— 排序算法

选择排序(简单选择排序堆排序的算法思想及代码实现)

选择排序

python学习选择排序算法简单代码