排序算法之选择排序

目录


一、简介

算法 平均时间复杂度 最好时间复杂度 最坏时间复杂度 空间复杂度 排序方式 稳定性
选择排序 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步,直到所有元素均排序完毕。


二、代码实现

java 复制代码
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实现)

相关推荐
iAkuya12 分钟前
(leetcode)力扣100 62N皇后问题 (普通回溯(使用set存储),位运算回溯)
算法·leetcode·职场和发展
近津薪荼12 分钟前
dfs专题5——(二叉搜索树中第 K 小的元素)
c++·学习·算法·深度优先
xiaoye-duck14 分钟前
吃透 C++ STL list:从基础使用到特性对比,解锁链表容器高效用法
c++·算法·stl
松☆17 分钟前
CANN与大模型推理:在边缘端高效运行7B参数语言模型的实践指南
人工智能·算法·语言模型
_F_y19 分钟前
C++重点知识总结
java·jvm·c++
打工的小王20 分钟前
Spring Boot(三)Spring Boot整合SpringMVC
java·spring boot·后端
毕设源码-赖学姐21 分钟前
【开题答辩全过程】以 高校体育场馆管理系统为例,包含答辩的问题和答案
java·spring boot
我真会写代码23 分钟前
SSM(指南一)---Maven项目管理从入门到精通|高质量实操指南
java·spring·tomcat·maven·ssm
vx_Biye_Design23 分钟前
【关注可免费领取源码】房屋出租系统的设计与实现--毕设附源码40805
java·spring boot·spring·spring cloud·servlet·eclipse·课程设计
java干货28 分钟前
为什么 “File 10“ 排在 “File 2“ 前面?解决文件名排序的终极算法:自然排序
开发语言·python·算法