排序算法之选择排序

简介: 选择排序(Selection sort)

选择排序(Selection sort)


1.什么是选择排序

选择排序是一种简单直观的排序算法,无论什么数据进去都是 O(n²) 的时间复杂度。所以用到它的时候,数据规模越小越好。唯一的好处可能就是不占用额外的内存空间了吧。


2.算法步骤

首先在排序序列中找到最小(最大)元素,存放到排序序列的起始位置。


再从剩余排序序列中继续寻找最小(最大)元素,然后放到已排序序列的末尾。


重复第二步,直到所有元素均排序完毕。


3.动图演示

1654611699643.png

4.代码演示

public static void main(String[] args) {
        //初始化数组
        int[] arr = {3,1,2,5,4};
        for (int i = 0; i < arr.length - 1; i++) {
            //最小值的下标
            int min = i;
            for (int j = i + 1; j < arr.length; j++) {
                //如果最小值比arr[j]还大,则记录最小元素的下标
                if (arr[min] > arr[j]) {
                    min = j;
                }
            }
            //如果i 不等于 最小值 则说明发生过改变,则交换位置
            if (i != min) {
                int temp = arr[i];
                arr[i] = arr[min];
                arr[min] = temp;
            }
        }
        System.out.println(Arrays.toString(arr));
    }

5.输出结果

[1, 2, 3, 4, 5]
相关文章
|
5月前
|
搜索推荐
选择排序与其它排序算法比较
选择排序与冒泡排序同属O(n²)排序算法,但选择排序不稳定。相比堆排序,虽每轮均选最大元素,但选择排序基于线性结构,效率较低,而堆排序利用大顶堆结构提升了选择效率。
107 0
|
搜索推荐 Java Go
深入了解选择排序算法
深入了解选择排序算法
159 4
|
算法 搜索推荐
数据结构与算法学习十一:冒泡排序、选择排序、插入排序
本文介绍了冒泡排序、选择排序和插入排序三种基础排序算法的原理、实现代码和测试结果。
491 0
数据结构与算法学习十一:冒泡排序、选择排序、插入排序
|
搜索推荐
冒泡排序(Bubble Sort)以及选择排序(Selection Sort)和快速排序(Quick Sort)详细解析
冒泡排序(Bubble Sort)以及选择排序(Selection Sort)和快速排序(Quick Sort)详细解析
260 1
|
搜索推荐 算法
【排序算法(一)】——插入排序,选择排序 —> 深层解析
【排序算法(一)】——插入排序,选择排序 —> 深层解析
|
算法 Python
Python算法编程:冒泡排序、选择排序、快速排序
Python算法编程:冒泡排序、选择排序、快速排序
181 0
|
搜索推荐 算法 Java
经典排序算法之-----选择排序(Java实现)
这篇文章通过Java代码示例详细解释了选择排序算法的实现过程,包括算法的基本思想、核心代码、辅助函数以及测试结果,展示了如何通过选择排序对数组进行升序排列。
经典排序算法之-----选择排序(Java实现)
|
机器学习/深度学习 算法 搜索推荐
数据结构算法--2 冒泡排序,选择排序,插入排序
**基础排序算法包括冒泡排序、选择排序和插入排序。冒泡排序通过相邻元素比较交换,逐步将最大值“冒”到末尾,平均时间复杂度为O(n^2)。选择排序每次找到剩余部分的最小值与未排序部分的第一个元素交换,同样具有O(n^2)的时间复杂度。插入排序则类似玩牌,将新元素插入到已排序部分的正确位置,也是O(n^2)复杂度。这些算法适用于小规模或部分有序的数据。**
排序算法---选择排序-----详解&&代码
排序算法---选择排序-----详解&&代码
|
算法 搜索推荐
数据结构与算法-选择排序
数据结构与算法-选择排序
121 4