排序算法之选择排序

选择排序的思想是每次从未排序的部分中选择最小的元素,然后将其放在已经排序部分的末尾。

  1. 遍历数组,从第一个元素开始,将其视为当前最小元素。
  2. 在未排序的部分中,找到最小的元素,并记录其索引。
  3. 将最小的元素与当前位置的元素交换位置
  4. 重复步骤2和步骤3,直到遍历完整个数组

比如有一个数组arr=[8,2,4,5,1,6,0,1]

我们要进行选择排序,先选择最小的,然后选择第二小的,然后是选择第三小的,依次类推。

选择排序是一种是原地排序算法

选择排序算法是不稳定的排序算法

执行流程

  1. 从序列中找出最大的哪个元素,然后于最末尾的元素交换位置
  2. 执行完一轮之后,最后的哪个元素就是最大的元素
  3. 忽略掉上一轮中找到的最大元素,重复执行步骤1
java 复制代码
package com.lut.sort;

import java.util.Arrays;

public class SelectionSort {


    public static void main(String[] args) {
        int[] arr = {8,2,4,5,1,6,0,1};
        selectionSort(arr);
        System.out.println(Arrays.toString(arr));

    }

    public static void selectionSort(int[] arr){
        int n = arr.length;//获取数组的长度

        for (int i = 0; i < n-1; i++) {
            int minIndex = i;

            for (int j = i; j < n; j++) {
                if(arr[j] < arr[minIndex]){
                    minIndex = j;
                }
            }

            int temp = arr[minIndex];
            arr[minIndex] = arr[i];
            arr[i] = temp;
        }
    }
}
相关推荐
rit843249911 分钟前
基于博弈论的小区分簇算法MATLAB实现
开发语言·算法·matlab
华清远见成都中心14 分钟前
C 语言内存管理深度解析:malloc/free 与嵌入式堆栈分配策略
java·c语言·算法
一行代码一行诗++19 分钟前
关系操作符
算法
努力努力再努力wz22 分钟前
【MySQL 进阶系列】拒绝滥用root:从 mysql.user 到权限校验,带你彻底理解用户管理与授权机制!
android·c语言·开发语言·数据结构·数据库·c++·mysql
生成论实验室1 小时前
《源·觉·知·行·事·物:生成论视域下的统一认知语法》第五章 事:行在时空中的具体化
人工智能·算法·架构·知识图谱·创业创新
炸膛坦客1 小时前
嵌入式 - 数据结构与算法:(1-4)数据结构 - 单链表的两个核心缺点(引入循环/双向链表)
c语言·数据结构·链表
Liangwei Lin1 小时前
LeetCode 283. 移动零
算法
Lenyiin1 小时前
《LeetCode 顺序刷题》61 - 70
java·c++·python·算法·leetcode·lenyiin
岁岁的O泡奶2 小时前
NSSCTF_crypto_[LitCTF 2023]babyLCG
经验分享·python·算法·密码学·crypto·流密码
Hesionberger2 小时前
LeetCode 78:子集生成全攻略
java·开发语言·数据结构·python·算法·leetcode·职场和发展