每天学习一个小算法:选择排序

选择排序


算法原理

  1. 把数组划分为 有序区间(左侧) + 无序区间(右侧)。
  2. 每一轮遍历无序区间,找到其中最小值(或最大值)的下标。
  3. 将找到的最值元素,与无序区间第一个元素交换。
  4. 有序区间向右扩大一格,重复上述步骤,直到整个数组有序。

核心思想:不断选最值,放到最前面。


一、适用场景

小规模数据排序(数据量很小,简单够用);

交换代价远大于比较代价 的场景(如硬件底层、老旧设备);

算法入门教学、笔试手写最简排序;

内存极度受限、不能开辟额外空间的极简环境;

对排序稳定性无要求、追求代码极简的临时排序。

二、复杂度分析

1.时间复杂度

  • 最好 / 平均 / 最坏:O(n²)
  • 无论数组是否接近有序,都要完整扫描无序区间,无优化,这是和插入排序最大区别。

2.空间复杂度

属于 原地排序,仅用常数级临时变量

  • O(1)

三、代码实现

1、Python实现

python 复制代码
def selection_sort(arr):
    n=len(arr)
    for i in range(n):
        min_idx=i
        for j in range(i+1,n):
            if arr[j]<arr[min_idx]:
                min_idx=j
        arr[i],arr[min_idx]=arr[min_idx],arr[i]
    return arr

2、Java实现

java 复制代码
public void selectionSort(int[] arr){
    int n=arr.length;
    for(int i=0;i<n;i++){
        int minIdx=i;
        for(int j=i+1;j<n;j++){
            if(arr[j]<arr[minIdx]) minIdx=j;
        }
        int t=arr[i];arr[i]=arr[minIdx];arr[minIdx]=t;
    }
}

3、C语言实现

c 复制代码
void selectionSort(int arr[],int n){
    int minIdx;
    for(int i=0;i<n-1;i++){
        minIdx=i;
        for(int j=i+1;j<n;j++)
            if(arr[j]<arr[minIdx]) minIdx=j;
        swap(&arr[i],&arr[minIdx]);
    }
}

总结

记录自己的快乐学习日志,也祝贺观看到这的小伙伴早日学有所成,财富自由💰💰。

记得点赞👍、收藏👋呀!!!

相关推荐
lizhihai_994 小时前
股市学习心得-股市的一天
学习
超级码力6664 小时前
【Latex第三方文档类standalone】standalone类介绍及应用
算法·数学建模·信息可视化
明朝百晓生4 小时前
强化学习 [chapter10] [page3 ]Actor-Critic Methods
算法
book123_0_994 小时前
Spring Boot 条件注解:@ConditionalOnProperty 完全解析
java·spring boot·后端
NCIN EXPE4 小时前
使用Springboot + netty 打造聊天服务(一)
java·spring boot·后端
.千余5 小时前
【Linux】进程概念
linux·服务器·开发语言·学习
peterfei5 小时前
一个 Tauri + Rust AI 编辑器是怎么同时适配 5 家 AI 大厂的?IfAI v0.4.3 架构拆解
人工智能·算法·架构
爱学习的小囧5 小时前
ESXi性能历史怎么监控?2种方法,图形化+命令行全覆盖
java·linux·运维·服务器·网络·esxi·esxi8.0
Via_Neo5 小时前
桶排序算法
算法·排序算法