选择排序笔记

文章目录

核心思想

选择排序是一种简单的 原地比较排序算法 ,其核心思想是:
每次从未排序部分选择最小(或最大)元素,放到已排序部分的末尾

快速排序基础版

javascript 复制代码
public class SelectSort{
  public static void selectSort(int[] arr){
    int n = arr.length;
    for(int i = 0; i < n - 1; i++){
      int minIndex = i;
      for(int j = i +1; j < n ; j++){
        if(arr[j] < arr[minIndex]){
          minIndex = j;
        }
      }
      swap(arr, i, minIndex);
    }
      
  }

  private static void swap(int[] arr, int i, int j) {
      int temp = arr[i];
      arr[i] = arr[j];
      arr[j] = temp;
  }
}

时间复杂度

  • 最好/最坏/平均情况均为 O(n²)(每次必须扫描剩余未排序部分)。
  • 比较次数:n(n-1)/2 次,与输入数据无关。

空间复杂度O(1)(原地排序)。

稳定性不稳定(交换可能破坏相等元素的相对顺序)。

补充:为什么选择排序不稳定?

示例:

原始数组 [5₁, 2, 5₂, 1](5₁ 和 5₂ 是值相同的两个元素)。

第一轮选择最小元素 1,与 5₁ 交换 → [1, 2, 5₂, 5₁]。

此时 5₂ 跑到了 5₁ 前面,相对顺序改变。

根本原因:

交换操作可能跨越多个位置,破坏相等元素的原始顺序。

快速排序优化版

思路(同时找最大和最小)

基础版就是每次在未排序的数中选一个最小的放到左边已排序的末尾,而优化版的快速排序就是每次不仅把最小的放到左边,也把最大的放到右边,减少遍历次数,这里的实现要结合双指针

javascript 复制代码
public class OptimizedSelectionSort{
  public static void optimizedSelectionSort(int[] arr){
    int left = 0, right = arr.length - 1;
    while(left < right){
      int minIndex = left;
      int maxIndex = right;
      // 1. 找到当前未排序部分的最小和最大值索引
      for(int i = left; i <= right; i++){
        if(arr[i] < arr[minIndex]) minIndex = i;
        if(arr[i] > arr[maxIndex]) maxIndex = i;
      }
    }

    swap(arr, left, minIndex);
    // 注意:如果最大值原本在left位置,它可能被换到minIndex位置
    if(maxIndex == left){
      maxIndex = minIndex;
    }

    swap(arr, right, maxIndex);
  }
} 
  • 每轮同时找到最小和最大值,减少总轮数(从 n 轮减少到 n/2 轮)。
相关推荐
当归102420 小时前
SQL Server死锁排查实战指南
java·服务器·网络
echoyu.20 小时前
消息队列-初识kafka
java·分布式·后端·spring cloud·中间件·架构·kafka
little_xianzhong20 小时前
关于对逾期提醒的定时任务~改进完善
java·数据库·spring boot·spring·mybatis
百锦再20 小时前
脚本语言的大浪淘沙或百花争艳
java·开发语言·人工智能·python·django·virtualenv·pygame
小猪咪piggy20 小时前
【JavaEE】(23) 综合练习--博客系统
java·数据库·java-ee
周航宇JoeZhou20 小时前
JP4-7-MyLesson后台前端(五)
java·前端·vue·elementplus·前端项目·mylesson·管理平台
David爱编程20 小时前
从 JVM 到内核:synchronized 与操作系统互斥量的深度联系
java·后端
渣哥20 小时前
Java Set 不会重复?原来它有“记仇”的本事!
java
一叶飘零_sweeeet20 小时前
从 0 到 1 攻克订单表分表分库:亿级流量下的数据库架构实战指南
java·数据库·mysql·数据库架构·分库分表
苹果醋320 小时前
数据库索引设计:在 MongoDB 中创建高效索引的策略
java·运维·spring boot·mysql·nginx