Java常见排序算法详解——选择排序

作者: Demo_Yang | 来源:发表于2019-04-09 00:01 被阅读35次

转载请注明出处:https://www.jianshu.com/p/43981d777731

选择排序Simple Selection Sort

概念:

是一种简单直观的排序算法。每一次遍历时选取关键字最小(或最大)的记录作为有序序列的第i个记录。

原理:

首先在未排序序列中找到最小(大)元素,存放到排序序列的起始位置,然后,再从剩余未排序元素中继续寻找最小(大)元素,然后放到已排序序列的末尾。以此类推,直到所有元素均排序完毕。
例如我们有一个数组,我们如果需要把较小的元素排在前面,把大的元素排在后面。

  1. 从数组当中,选择出最小的那个元素放在第一个位置。
  2. 如果没有比当前还小的元素,那么就在当前的位置不变。
  3. 继续对越来越少的数据进行比较、交换操作,直到没有可比较的数据为止,排序完成。
图解实例:

假如我们有一个数组 [11 10 5 7 4 29]
我们从这个数组当中,找到最小的数字4和第一个数字11交换位置。

最小             min
                  ↓              
11   10   5   7   4   29   
↑                 ↑
└─────────────────┘

交换之后数组如下:

4   10   5   7   11   29 

在剩余的序列当中,找到最小的数字5和剩余序列的第一个位置10交换位置

最小    min
         ↓              
4   10   5   7   4   29   
    ↑    ↑
    └────┘

交换之后数组如下:

4   5   10   7   11   29 

在剩余的序列当中,找到最小的数字7和剩余序列的第一个位置10交换位置

最小        min
             ↓              
4   5   10   7   11   29   
        ↑    ↑
        └────┘

交换之后数组如下:

4   5   7   10   11   29 

可以看到,我们已经按照从小到大的顺序排好了。
选择排序的主要优点与数据移动有关。如果某个元素位于正确的最终位置上,则它不会被移动。选择排序每次交换一对元素,它们当中至少有一个将被移到其最终位置上,因此对n个元素的序列进行排序总共进行至多n-1次交换。在所有的完全依靠交换去移动元素的排序方法中,选择排序属于非常好的一种。

代码实现:
/**
 * @author yangzc
 * @data 2019/4/8 23:37
 * @desc 选择排序
 */
public class SelectSort {
    private int[] array;

    public SelectSort(int[] array) {
        this.array = array;
    }

    //从小到大
    public void selectionSort() {
        int min, temp;
        for (int i = 0; i < array.length; i++) {
            // 初始化未排序序列中最小数据数组下标
            min = i;
            for (int j = i + 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 void selectionSort2() {
        int max, temp;
        for (int i = 0; i < array.length; i++) {
            // 初始化未排序序列中最小数据数组下标
            max = i;
            for (int j = i + 1; j < array.length; j++) {
                // 在未排序元素中继续寻找最小元素,并保存其下标
                if (array[j] > array[max]) {
                    max = j;
                }
            }
            // 将未排序列中最小元素放到已排序列末尾
            if (max != i) {
                temp = array[max];
                array[max] = array[i];
                array[i] = temp;
            }
        }
    }

    public String print(String s, String Tag) {
        Log.d(Tag, Arrays.toString(array));
        return s + Arrays.toString(array);
    }
}

算法系列:

冒泡排序
直接插入排序
二分插入排序

完整代码:

Java和Kotlin代码我均放在了GitHub上,欢迎Star!

GitHub地址:https://github.com/yang0range/MyAlgorithm

欢迎关注公共号

关注公共号会有更多收获!

扫一扫,据说年轻、优秀、颜值高的互联网人都在这个群里

相关文章

  • Java常见排序算法详解——选择排序

    转载请注明出处:https://www.jianshu.com/p/43981d777731 选择排序Simple...

  • 排序算法

    常见排序算法及JAVA实现 简单选择排序(SelectSort) 选择排序思想很简单,对所有元素进行遍历,选出最小...

  • LeetCode大全

    1.常见排序算法: 常见的排序算法:冒泡排序、选择排序、插入排序、归并排序、快速排序、希尔排序、堆排序、计数排序、...

  • 排序算法(四) 希尔排序(插入排序的进化)

    参考Java排序算法(四):希尔排序常见排序算法 - 希尔排序 (Shell Sort) 希尔排序算法是按其设计者...

  • 盘点常用Java排序算法

    本文主要介绍Java的七种常见排序算法的实现,对选择排序、插入排序、冒泡排序、归并排序、快速排序、希尔排序、最小堆...

  • 盘点常用Java排序算法

    本文主要介绍Java的七种常见排序算法的实现,对选择排序、插入排序、冒泡排序、归并排序、快速排序、希尔排序、最小堆...

  • Python知识点:常见算法的python实现

    提到排序算法,常见的有如下几种:冒泡排序、选择排序、插入排序、快速排序、堆排序、归并排序、希尔排序;查找算法最常见...

  • IOS常见算法

    常见算法: 快速排序: 选择排序: 冒泡排序: 测试代码:

  • PHP常用算法

    基于选择的排序算法 常见的基于选择的排序算法有:冒泡排序、插入排序、选择排序、归并排序和快速排序,我们在选在排序算...

  • 排序算法

    常见的排序算法 常见的排序算法有:插入、希尔、选择、冒泡、归并、快速、堆排序。。。 插入排序 算法步骤一、从数组的...

网友评论

    本文标题:Java常见排序算法详解——选择排序

    本文链接:https://www.haomeiwen.com/subject/kwtviqtx.html