选择排序 no implementation java
选择排序(Selection sort)是一种简单直观的排序算法。它的工做原理是每一次从待排序的元素中中选出最小(或最大)的一个元素,存放在序列的起始位置,直到所有待排序的数据元素排完。 选择排序是不稳定的排序方法git
选择排序图解。假设你有以下的数组须要排序github
第一次。我先遍历一边数组找出最小的值, 发现是index = 1 的位置 value = 1, 交换index = 0 和index = 1 的位置。算法
这个时候, index = 0 的位置已经排好了。咱们接着从index = 1 的位置开始排序发现 最小的值是2。交换位置数组
重复刚才的步骤就能够获得排好后的数组less
选择排序须要的比较次数是N^2. O(N^2) ide
由于比较简单,下面直接给出代码spa
// O(n^2) 很是慢 public static void sort(Comparable[] a) { for (int i = 0; i < a.length; i++) { int min = i; for (int j = i; j < a.length; j++) { if (less(a[j], a[min])) min = j; } exch(a, i, min); } }
具体的实现能够参考3d
https://github.com/Cheemion/algorithms/blob/master/src/com/algorithms/sort/SelectionSort.javacode