博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Java排序算法之直接选择排序
阅读量:4677 次
发布时间:2019-06-09

本文共 1543 字,大约阅读时间需要 5 分钟。

Java排序算法之直接选择排序

基本过程:假设一序列为R[0]~R[n-1],第一次用R[0]和R[1]~R[n-1]相比较,若小于R[0],则交换至R[0]位置上。第二次从R[1]~R[n-1]中选取最小值,与R[1]交换,....,第i次从R[i-1]~R[n-1]中选取最小值,与R[i-1]交换,.....,第n-1次从R[n-2]~R[n-1]中选取最小值,与R[n-2]交换,总共通过n-1次,得到一个按排序码从小到大排列的有序序列。

Java代码实现:

 

public class Xuanze {    public static void main(String[] args) {        int [] s = {8,3,2,1,7,4,6,5};        int temp = 0;        for(int i=0;i
s[j]){ temp=s[i]; s[i]=s[j]; s[j]=temp; } } } for(int value:s) System.out.print(value); }}

 

上面排序方法存在效率问题。因为当我们发现当前数比被比较数小的时候我们就交换两个数,其实我们可以把当前数的位置保存下来,等到第一次比较完后在进行交换。

public class Xuanze {        public static void main(String[] args) {                int [] s = {8,3,2,1,7,4,6,5};        int temp = 0;        for(int i=0;i
s[j]){ temp=j; //保存位置 } } if(temp!=i) exchang(s,i,temp); //进行交换 } for(int value:s) System.out.print(value); } private static void exchang(int[] s, int i, int j) { int temp = s[j]; s[j]=s[i]; s[i]=temp; }}

算法性能分析:

时间复杂度:假设有n个数据,数据交换的次数最多为n-1次,但程序的总体的比较次数较多。所以综合考虑有直接选择排序的时间复杂度为O(n2)

       (n的平方)。所以当记录占用字节数较多时,通常比直接插入排序的执行速度快些。

空间复杂度:直接选择排序的空间复杂度很好,它只需要一个附加单元用于数据交换,所以其空间复杂度为O(1)。

稳定性:在一趟选择,如果当前元素比一个元素小,而该小的元素又出现在一个和当前元素相等的元素后面,那么 交换后稳定性就被破坏了。举个例子,序列5 8 5 2 9, 我们知道第一遍选择第1个元素5会和2交换,那么原序列中2个5的相对前后顺序就被破坏了,所以选择排序不是一个稳定的排序算法。

 

转载于:https://www.cnblogs.com/love-Stefanie/p/6636342.html

你可能感兴趣的文章
jackson的自动检测机制
查看>>
2019 计蒜之道 初赛 第二场 B. 百度AI小课堂-上升子序列(简单) ( 实现)
查看>>
Python(2.7)-随机函数(random)
查看>>
Mybatis学习笔记(一) 之框架原理
查看>>
ABSTRACT的方法是否可同时是STATIC,是否可同时是NATIVE,是否可同时是SYNCHRONIZED?
查看>>
【SPL标准库专题(10)】SPL Exceptions
查看>>
《Python从入门基础到实践》
查看>>
【读入优化】
查看>>
python-网络编程urllib模块
查看>>
0029 Java学习笔记-面向对象-枚举类
查看>>
CGRectGet *** 获取控件坐标的方法
查看>>
SQL的主键和外键约束
查看>>
Bookmarklet
查看>>
c++primer 第l六章编程练习答案
查看>>
上海秋季HCC小记
查看>>
Illustrator 上色
查看>>
truncate表恢复
查看>>
this关键字的使用
查看>>
Console.Read()、Console.ReadLine()、Console.ReadKey()
查看>>
ecere 编译过程中遇到的问题
查看>>