深入浅出排序算法之简单选择排序

简介: 深入浅出排序算法之简单选择排序

1. 原理和执行流程

选择排序包含了堆排序和简单选择排序。

每一次从无序区间选出最大(或最小)的一个元素,存放在无序区间的最后(或最前),直到全部待排序的数据元素排完 。

选择类排序的主要动作是“选择”,简单选择排序采用最简单的选择方式,从头至尾顺序扫描序列。找出最小的一个关键字,和第一个关键字交换,接着从剩下的关键字中继续这种选择和交换,最终使序列有序。

2. 代码实现

//选择排序
    public static void selectSort(int[] array){
        for(int i = 0;i < array.length - 1;i++){
            //剩下最后一个元素,不需要选择了,因为已经在最合适的位置
            boolean flag = false;//用来比较是否更好minIndex的值
            int j = i + 1;//往后一位进行比较
            int minIndex = i;
            for(;j < array.length;j++){
                if(array[minIndex] > array[j]){
                    minIndex = j;
                    flag = true;
                }
            }
            if(flag){
                int tmp = array[minIndex];
                array[minIndex] = array[i];
                array[i] = tmp;
            }
        }
    }
    public static void main(String[] args) {
        int[] arr = {3,1,2,4,5};
        Sort.selectSort(arr);
        for (int x : arr) {
            System.out.print(x + " ");
        }
    }

3. 性能分析

时间复杂度 空间复杂度
O(N^2) O(1)
数据不敏感 数据不敏感

4. 双向选择排序(了解)

每一次从无序区间选出最小 + 最大的元素,存放在无序区间的最前和最后,直到全部待排序的数据元素排完 。

public static void main(String[] args) {
        int[] arr = {5,2,1,3,4};
        Sort.selectSortOP(arr);
        for (int x : arr) {
            System.out.print(x + " ");
        }
    }
    //双向选择排序
    //和单向的时间复杂度一致,可能只是更帅一点吧
    public static void selectSortOP(int[] array){
        int low = 0;
        int high = array.length - 1;
        // [low, high] 表示整个无序区间
        // 无序区间内只有一个数也可以停止排序了
        while(low < high){
            int min = low;
            int max = low;
            for(int i = low + 1;i <= high;i++){
                if (array[i] < array[min]) {
                    min = i;
                }
                if(array[i] > array[max]){
                    max = i;
                }
            }
            swap(array,low,min);
            //见下面解析:最大值可能在low的位置上,min和low一交换,最大值就到了min的位置
            if(max == low){
                max = min;
            }
            swap(array,high,max);
            low++;
            high--;
        }
    }
array = { 9, 5, 2, 7, 3, 6, 8 }; // 交换之前
// low = 0; high = 6
// max = 0; min = 2
array = { 2, 5, 9, 7, 3, 6, 8 }; // 将最小的交换到无序区间的最开始后
// max = 0,但实际上最大的数已经不在 0 位置,而是被交换到 min 即 2 位置了
// 所以需要让 max = min 即 max = 2
array = { 2, 5, 8, 7, 3, 6, 9 }; // 将最大的交换到无序区间的最结尾后

相关文章
|
2月前
|
算法 搜索推荐
数据结构与算法学习十一:冒泡排序、选择排序、插入排序
本文介绍了冒泡排序、选择排序和插入排序三种基础排序算法的原理、实现代码和测试结果。
21 0
数据结构与算法学习十一:冒泡排序、选择排序、插入排序
|
2月前
|
搜索推荐 Java Go
深入了解选择排序算法
深入了解选择排序算法
25 4
|
2月前
|
搜索推荐 算法
【排序算法(一)】——插入排序,选择排序 —> 深层解析
【排序算法(一)】——插入排序,选择排序 —> 深层解析
|
2月前
|
算法 Python
Python算法编程:冒泡排序、选择排序、快速排序
Python算法编程:冒泡排序、选择排序、快速排序
|
4月前
|
搜索推荐 算法 Java
经典排序算法之-----选择排序(Java实现)
这篇文章通过Java代码示例详细解释了选择排序算法的实现过程,包括算法的基本思想、核心代码、辅助函数以及测试结果,展示了如何通过选择排序对数组进行升序排列。
经典排序算法之-----选择排序(Java实现)
|
6月前
|
机器学习/深度学习 算法 搜索推荐
数据结构算法--2 冒泡排序,选择排序,插入排序
**基础排序算法包括冒泡排序、选择排序和插入排序。冒泡排序通过相邻元素比较交换,逐步将最大值“冒”到末尾,平均时间复杂度为O(n^2)。选择排序每次找到剩余部分的最小值与未排序部分的第一个元素交换,同样具有O(n^2)的时间复杂度。插入排序则类似玩牌,将新元素插入到已排序部分的正确位置,也是O(n^2)复杂度。这些算法适用于小规模或部分有序的数据。**
|
6月前
|
搜索推荐
排序算法---选择排序-----详解&&代码
排序算法---选择排序-----详解&&代码
|
6月前
|
算法 搜索推荐
数据结构与算法-选择排序
数据结构与算法-选择排序
33 4
|
6月前
|
搜索推荐 算法
【C/排序算法】:堆排序和选择排序
【C/排序算法】:堆排序和选择排序
36 0
|
6月前
|
算法 搜索推荐 Java
JavaSE——算法(1/2):认识、冒泡排序、选择排序及优化(介绍、详细图解、代码)
JavaSE——算法(1/2):认识、冒泡排序、选择排序及优化(介绍、详细图解、代码)
39 0