排序算法之选择排序

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

  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;
        }
    }
}
相关推荐
CoovallyAIHub10 分钟前
开源:YOLO最强对手?D-FINE目标检测与实例分割框架深度解析
人工智能·算法·github
CoovallyAIHub30 分钟前
OpenClaw:从“19万星标”到“行业封杀”,这只“赛博龙虾”究竟触动了谁的神经?
算法·架构·github
刀法如飞38 分钟前
程序员必须知道的核心算法思想
算法·编程开发·算法思想
徐小夕2 小时前
pxcharts Ultra V2.3更新:多维表一键导出 PDF,渲染兼容性拉满!
vue.js·算法·github
CoovallyAIHub3 小时前
OpenClaw一脚踩碎传统CV?机器终于不再只是看世界
深度学习·算法·计算机视觉
CoovallyAIHub3 小时前
仅凭单目相机实现3D锥桶定位?UNet-RKNet破解自动驾驶锥桶检测难题
深度学习·算法·计算机视觉
zone77393 小时前
002:RAG 入门-LangChain 读取文本
后端·算法·面试
得物技术4 小时前
得物社区搜推公式融合调参框架-加乘树3.0实战
算法
程序员爱钓鱼21 小时前
Go 操作 Windows COM 自动化实战:深入解析 go-ole
后端·go·排序算法
会员源码网1 天前
使用`mysql_*`废弃函数(PHP7+完全移除,导致代码无法运行)
后端·算法