排序算法之选择排序


一、简介

算法 平均时间复杂度 最好时间复杂度 最坏时间复杂度 空间复杂度 排序方式 稳定性
选择排序 O(n^2 ) O(n^2) O(n^2) O(1) In-place 不稳定

稳定:如果A原本在B前面,而A=B,排序之后A仍然在B的前面;
不稳定:如果A原本在B的前面,而A=B,排序之后A可能会出现在B的后面;
时间复杂度: 描述一个算法执行所耗费的时间;
空间复杂度:描述一个算法执行所需内存的大小;
n:数据规模;
k:“桶”的个数;
In-place:占用常数内存,不占用额外内存;
Out-place:占用额外内存。

在这里插入图片描述

算法步驟:

首先在未排序序列中找到最小(大)元素,存放到排序序列的起始位置;
再从剩余未排序元素中继续寻找最小(大)元素,然后放到已排序序列的末尾;
重复第2步,直到所有元素均排序完毕。


二、代码实现

public class SelectionSort {

    public static void selectionSort(int[] arr) {
        int len = arr.length;
        for (int i = 0; i < len - 1; i++) {
            int minVal = i;
            for (int j = i + 1; j < len; j++) {
                if (arr[minVal] > arr[j]) {
                    minVal = j;
                }
            }
            if (minVal != i) {
                int tmp = arr[i];
                arr[i] = arr[minVal];
                arr[minVal] = tmp;
            }
        }
    }

    public static void selectionSort2(int[] arr) {
        int len = arr.length;
        for (int i = 0; i < len - 1; i++) {
            int maxVal = i;
            for (int j = i + 1; j < len; j++) {
                if (arr[maxVal] < arr[j]) {
                    maxVal = j;
                }
            }
            if (maxVal != i) {
                int tmp = arr[i];
                arr[i] = arr[maxVal];
                arr[maxVal] = tmp;
            }
        }
    }

    public static void main(String[] args) {
        int[] arr = {12, 11, 15, 50, 7, 65, 3, 99};
        System.out.println("---排序前:  " + Arrays.toString(arr));
        selectionSort(arr);
        System.out.println("选择排序从小到大:  " + Arrays.toString(arr));
        selectionSort2(arr);
        System.out.println("选择排序从大到小:  " + Arrays.toString(arr));
    }

}

在这里插入图片描述

三、应用场景

和冒泡排序一致,相比其它排序算法,这也是一个相对较高的时间复杂度,一般情况不推荐使用。
但是我们还是要掌握冒泡排序的思想及实现,这对于我们的算法思维是有很大帮助的

参考链接:
十大经典排序算法(Java实现)

相关推荐

  1. 算法选择排序

    2024-04-13 14:54:01       32 阅读
  2. 排序算法——选择排序

    2024-04-13 14:54:01       40 阅读

最近更新

  1. TCP协议是安全的吗?

    2024-04-13 14:54:01       18 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2024-04-13 14:54:01       19 阅读
  3. 【Python教程】压缩PDF文件大小

    2024-04-13 14:54:01       19 阅读
  4. 通过文章id递归查询所有评论(xml)

    2024-04-13 14:54:01       20 阅读

热门阅读

  1. 掌握 Python 迭代:循环和列表推导的魔力

    2024-04-13 14:54:01       11 阅读
  2. CSS学习笔记

    2024-04-13 14:54:01       16 阅读
  3. spring-ioc三层架构测试

    2024-04-13 14:54:01       14 阅读
  4. Python教程:深入了解Python垃圾回收机制

    2024-04-13 14:54:01       15 阅读
  5. 从零起步学C++笔记(一)-简单程序设计

    2024-04-13 14:54:01       14 阅读
  6. 【资料】华为硬件工程师手册与资料

    2024-04-13 14:54:01       14 阅读
  7. C++菜单查询

    2024-04-13 14:54:01       13 阅读
  8. Leetcode27题:移除元素【27/1000 python】

    2024-04-13 14:54:01       11 阅读
  9. Python脚本式编程

    2024-04-13 14:54:01       13 阅读
  10. 蓝桥杯备考随手记: 常见的二维数组问题

    2024-04-13 14:54:01       15 阅读
  11. 光伏发的电可以存储在哪里?

    2024-04-13 14:54:01       45 阅读
  12. linux c多进程通信之共享内存和信号量

    2024-04-13 14:54:01       17 阅读
  13. 蓝桥杯 2022 省 B 洛谷P8783 统计子矩阵

    2024-04-13 14:54:01       15 阅读