简单选择排序算法原理及JAVA实现

12 篇文章 1 订阅

简单选择排序:(选出最小值,放在第一位,然后第一位向后推移,如此循环)第一位与后面每一个逐个比较,每次都使最小的置顶,第一位向后推进(即刚选定的第一位是最小值,不再参与比较,比较次数减1)

复杂度
: 所需进行记录移动的操作次数较少 0--3(n-1) ,无论记录的初始排列如何,所需的关键字间的比较次数相同,均为n(n-1)/2,总的时间复杂度为O(n2);
空间复杂度 O(1)

算法改进:每次对比,都是为了将最小的值放到第一位,所以可以一比到底,找出最小值,直接放到第一位,省去无意义的调换移动操作。也可以换一个方向,最后一位与前面每一个比较,每次使最大值沉底,最后一位向前推进。


JAVA源代码(成功运行):

public static void main(String[] args) {
		int[] array = { 49, 38, 65, 97, 76, 13, 27 };
		selectSort(array);
		for (int i = 0; i < array.length; i++) {
			System.out.println(array[i]);
		}
	}
	public static void selectSort(int[] array){
		int temp;
		int min;
		for(int i=0;i<array.length;i++){
			min=i;
			for(int j=min+1;j<array.length;j++){
				if(array[j]<array[min]){
					min=j;
				}
			}
			if(min!=i){
				temp=array[min];
				array[min]=array[i];
				array[i]=temp;
			}
		}
	}

自己理解的写法:

/**
 * 简单选择排序
 *
 */
public class SimpleSelectSort {

	public static void main(String[] args) {  
        int[] array = { 49, 38, 65, 97, 76, 13, 27 };  
        selectSort(array);  
        for (int i = 0; i < array.length; i++) {  
            System.out.println(array[i]);  
        }  
    }  
	public static void selectSort(int[] array){
		int minIndex;
		int tempValue;
		for(int i=0;i<array.length;i++){//用于记录最小值得位置
			minIndex=i;
			for(int j=minIndex+1;j<array.length;j++){//从最小值的下个位置开始比较
				if(array[minIndex]>array[j]){
					minIndex=j;
				}
			}
			if(minIndex!=i){//如果最小值没有变化不互调位置
				tempValue=array[minIndex];	
				array[minIndex]=array[i];
				array[i]=tempValue;
			}
		}
	} 
}




转载于:http://blog.csdn.net/xuxurui007/article/details/7640522


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值