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

选择排序


算法原理

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

总结

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

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

相关推荐
考虑考虑2 小时前
Mybatis实现批量插入
java·后端·mybatis
咖啡八杯3 小时前
GoF设计模式——中介者模式
java·后端·spring·设计模式
青石路7 小时前
记一次多JDK版本问题的排查,一坑套一坑,差点没爬上来
java
先吃饱再说8 小时前
判断回文字符串,从一行代码到双指针优化
算法
像我这样帅的人丶你还10 小时前
Java 后端详解(五):Redis 缓存
java·后端·全栈
黄敬峰11 小时前
深入理解算法核心:从递归思想、数组扁平化到快速排序
算法
plainGeekDev12 小时前
GreenDAO → Room
android·java·kotlin
得物技术12 小时前
从狂野代码到按目标生产:得物推荐 AI Harness 的工程化实践|AICon 演讲整理
人工智能·算法·架构
AI小老六16 小时前
SkillOpt 架构拆解:把 Skill 文本当参数,用执行轨迹训练 Agent
后端·算法·ai编程