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

选择排序


算法原理

  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]);
    }
}

总结

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

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

相关推荐
NNYSJYKJ几秒前
K12 学习常见问题破解:脑能思维链的算法与教育应用
学习·算法
要开心吖ZSH几秒前
零基础入门 Spring WebFlux 与 Project Reactor:从小白到顿悟
java·响应式编程·spring webflux
智塑未来几秒前
装备制造行业设计制造一体化痛点攻克与实战经验总结
java·开发语言·制造
Shadow(⊙o⊙)4 分钟前
硬核手搓解析!进程-内核分析:命令行参数及环境变量,重构main()
linux·运维·服务器·开发语言·c++·后端·学习
星夜夏空994 分钟前
STM32单片机学习(11)——GPIO输入实验
stm32·单片机·学习
Devin~Y6 分钟前
电商AIGC智能客服面试:JVM调优、Spring Cloud微服务、Redis缓存、Kafka消息、K8s观测与RAG落地
java·jvm·spring boot·redis·spring cloud·kafka·kubernetes
Ai马猴子8 分钟前
企业定制专属模型,gpt-5.4-cdx高效适配,DMXAPI 安全合规
java·gpt·安全
2301_789015629 分钟前
Linux:基础指令(二)
linux·运维·服务器·c语言·开发语言·c++·算法
开开心心就好10 分钟前
支持添加网址的资源快速打开工具
人工智能·学习·游戏·音视频·hbase·语音识别·storm
星晨羽12 分钟前
Java通过FTP协议实现文件上传下载
java·开发语言