Java排序算法总结(二):选择排序

开发 后端 算法

选择排序的基本操作就是每一趟从待排序的数据元素中选出最小(或最大)的一个元素,顺序放在已排好序的数列的最后,直到全部待排序的数据元素排完。算法不稳定,O(1)的额外的空间,比较的时间复杂度为O(n^2),交换的时间复杂度为O(n),并不是自适应的。在大多数情况下都不推荐使用。只有在希望减少交换次数的情况下可以用。

基本思想

n个记录的文件的直接选择排序可经过n-1趟直接选择排序得到有序结果:   

①初始状态:无序区为R[1..n],有序区为空。   

②第1趟排序   

在无序区R[1..n]中选出关键字最小的记录R[k],将它与无序区的第1个记录R[1]交换,使R[1..1]和R[2..n]分别变为记录个数增加1个的新有序区和记录个数减少1个的新无序区。   

……

 ③第i趟排序   

第i趟排序开始时,当前有序区和无序区分别为R[1..i-1]和R(1≤i≤n-1)。该趟排序从当前无序区中选出关键字最小的记录 R[k],将它与无序区的第1个记录R交换,使R[1..i]和R分别变为记录个数增加1个的新有序区和记录个数减少1个的新无序区。   

这样,n个记录的文件的直接选择排序可经过n-1趟直接选择排序得到有序结果。   

代码实现

  1. public class Test {   
  2. public static int[] a = { 1032195712043 }; // 预设数据数组   
  3. public static void main(String args[]) {   
  4. int i; // 循环计数变量   
  5. int Index = a.length;// 数据索引变量   
  6. System.out.print("排序前: ");   
  7. for (i = 0; i < Index - 1; i++)   
  8. System.out.printf("%3s", a);   
  9. System.out.println("");   
  10. SelectSort(Index - 1); // 选择排序   
  11. // 排序后结果   
  12. System.out.print("排序后: ");   
  13. for (i = 0; i < Index - 1; i++)   
  14. System.out.printf("%3s", a);   
  15. System.out.println("");   
  16. }   
  17. public static void SelectSort(int Index) {   
  18. int i, j, k; // 循环计数变量   
  19. int MinValue; // 最小值变量   
  20. int IndexMin; // 最小值索引变量   
  21. int Temp; // 暂存变量   
  22. for (i = 0; i < Index - 1; i++) {   
  23. MinValue = 32767// 目前最小数值   
  24. IndexMin = 0// 储存最小数值的索引值   
  25. for (j = i; j < Index; j++) {   
  26. if (a[j] < MinValue) // 找到最小值   
  27. {   
  28. MinValue = a[j]; // 储存最小值   
  29. IndexMin = j;   
  30. }   
  31. Temp = a; // 交换两数值   
  32. a = a;   
  33. a = Temp;   
  34. }   
  35. System.out.print("排序中: ");   
  36. for (k = 0; k < Index; k++)   
  37. System.out.printf("%3s", a[k]);   
  38. System.out.println("");   
  39. }   
  40. }   

选择排序法与冒泡排序法一样,最外层循环仍然要执行n-1次,其效率仍然较差。

【编辑推荐】

  1. 5.5.5 使用直接选择排序法
  2. C#算法之选择排序浅析
  3. 经典四讲贯通C++排序之四 选择排序
责任编辑:于铁 来源: 百度
相关推荐

2011-04-20 14:07:37

冒泡排序

2011-04-20 14:19:00

希尔排序

2011-04-20 15:06:44

堆排序

2011-04-20 15:20:03

快速排序

2011-04-20 14:29:07

归并排序

2011-04-20 12:49:44

插入排序

2011-04-20 16:05:15

基数排序

2015-08-26 10:13:55

排序算法总结

2019-09-17 16:30:18

java排序算法

2023-03-06 08:10:52

数据结构算法数据

2023-09-26 22:22:30

选择排序Python

2015-09-01 10:21:53

排序算法总结

2021-01-21 05:22:36

排序算法选择

2015-10-20 15:09:55

排序算法

2009-08-11 09:19:52

C#选择排序C#算法

2019-10-30 08:53:46

JavaScript冒泡排序选择排序

2021-01-26 05:33:07

排序算法快速

2023-10-05 09:01:05

插入排序对象序列log2i

2022-01-06 16:20:04

Java排序算法排序

2021-01-19 07:02:26

算法数据结构堆排序
点赞
收藏

51CTO技术栈公众号