排序算法之选择排序

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

  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;
        }
    }
}
相关推荐
Mr. zhihao6 分钟前
Redis五大高级数据结构:原理-场景-底层-横向对比
数据结构·redis
QiLinkOS18 分钟前
【从实验室到商业战场:发明专利如何重塑科技与企业的共生生态】
大数据·c语言·数据结构·c++·人工智能·单片机·算法
如此这般英俊44 分钟前
手撕Claude Code—第一章 agent-loop
数据结构·人工智能·语言模型·自然语言处理
小白兔奶糖ovo1 小时前
【Leetcode】231. 2的幂
linux·算法·leetcode
xiaoxiaoxiaolll1 小时前
《Light: Science & Applications》合并BIC实现80倍阈值单模运行:超紧凑光子晶体激光器新突破
人工智能·算法·机器学习
Peter·Pan爱编程1 小时前
14. Lambda 表达式:随手可写的函数对象
c++·算法·ai编程
-To be number.wan1 小时前
算法日记 | 暴力枚举
学习·算法
s_w.h2 小时前
【 linux 】动静态库的制作
linux·运维·服务器·算法·bash
过期动态2 小时前
【LeetCode 热题 100】接雨水
java·数据结构·算法·leetcode·职场和发展
春日见2 小时前
5分钟入门强化学习之动态规划算法与实现
大数据·人工智能·python·算法·机器学习·计算机视觉