• 选择排序算法Java实现


    一. 算法描述   

    选择排序:比如在一个长度为N的无序数组中,在第一趟遍历N个数据,找出其中最小的数值与第一个元素交换,第二趟遍历剩下的N-1个数据,找出其中最小的数值与第二个元素交换......第N-1趟遍历剩下的2个数据,找出其中最小的数值与第N-1个元素交换,至此选择排序完成。

    以下面5个无序的数据为例:

    56 12 80 91 20(文中仅细化了第一趟的选择过程)

    第1趟:12 56 80 91 20

    第2趟:12 20 80 91 56

    第3趟:12 20 56 91 80

    第4趟:12 20 56 80 91

    二. 算法分析

    平均时间复杂度:O(n2)

    空间复杂度:O(1)  (用于交换和记录索引)

    稳定性:不稳定 (比如序列【5, 5, 3】第一趟就将第一个[5]与[3]交换,导致第一个5挪动到第二个5后面)

    三. 算法实现

      

    package com.neuedu.algorithm;
    
    public class Selectsort {
    //选择排序 
    	public static void choiceSort(Integer [] a){
    		if(a==null||a.length<=0){
    		return;
    		}
    		for(int i=0;i<a.length;i++){
    		int min=i;/*将当前下标定义为最小值下标*/
    
    		for(int j=i+1;j<a.length;j++){
    		if(a[min]>a[j]){/*如果有小于当前最小值的关键字*/
    		min=j;/*将此关键字的下标赋值给min*/
    		    }
    		 }
    		if(i!=min){/*若min不等于i,说明找到最小值,交换*/
    		int tmp=a[min];
    		a[min]=a[i];
    		a[i]=tmp;
    		   }
    		  }		
    	}
    	public static void main(String[] args) {
    		Integer[] list={49,38,65,97,76,13,27,14,10};
    		//快速排序  
    		 Selectsort.choiceSort(list);
    		 for (Integer integer : list) {
    			System.out.print(integer+"  ");
    		}
    	}
    }
    

      

  • 相关阅读:
    MyEclipse修改默认的workspace路径
    对象池化技术 org.apache.commons.pool
    Java 简单工厂模式
    组装品入力
    引当日数和JAN日数的意思
    材料构成模块的做法
    在库移动和在库振替的意思
    组装品的特殊式样
    设计的尝试数据库・数据的更新
    定时器(Timer)文章收集转载(小雨论坛)
  • 原文地址:https://www.cnblogs.com/lc-java/p/7930425.html
Copyright © 2020-2023  润新知