Java实例7 - 选择排序 Selection Sort

[java]  view plain copy
  1. /** 
  2.  *  选择排序的思想: 
  3.  *  每次从待排序列中找到最小的元素, 
  4.  *  然后将其放到待排的序列的最左边,直到所有元素有序 
  5.  *   
  6.  *  选择排序改进了冒泡排序,将交换次数从O(N^2)减少到O(N) 
  7.  *  不过比较次数还是O(N) 
  8.  */  
  9. package al;  
  10. public class SelectSort {  
  11.       
  12.     public static void main(String[] args) {  
  13.           
  14.         SelectSort selectSort = new SelectSort();  
  15.         int[] elements = { 147721910504314 };  
  16.         // sort the array  
  17.         selectSort.sort(elements);  
  18.         // print the sorted array  
  19.         for (int i = 0; i < elements.length; i++) {  
  20.             System.out.print(elements[i]);  
  21.             System.out.print(" ");  
  22.         }  
  23.     }  
  24.       
  25.     /** 
  26.      * @author 
  27.      * @param array 待排数组 
  28.      */  
  29.     public void sort(int[] array) {  
  30.         // min to save the minimum element for each round  
  31.         int min, tmp;  
  32.           
  33.         for(int i=0; i<array.length; i++) {  
  34.             min = i;  
  35.             // search for the minimum element  
  36.             for(int j=i; j<array.length; j++) {  
  37.                 if(array[j] < array[min]) {  
  38.                     min = j;  
  39.                 }                 
  40.             }  
  41.             // swap minimum element  
  42.             tmp = array[i];  
  43.             array[i] = array[min];  
  44.             array[min] = tmp;             
  45.         }  
  46.     }  
  47. }  
  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值