排序 - 选择 (selection sort)

文章目录

  • [1 . 前言](#1 . 前言)
  • [2 . 选择原理](#2 . 选择原理)
  • [3 . 代码实现](#3 . 代码实现)
  • [4 . 时间复杂度](#4 . 时间复杂度)
  • [5 . 总结](#5 . 总结)

【全文大纲】 : https://blog.csdn.net/Engineer_LU/article/details/135149485


1 . 前言

数据整理过程中经常需要把数据排序,这篇文章主要详解选择排序

2 . 选择原理

  1. 选择排序与冒泡排序很像,选择排序每一趟找到最小值(最大值也可以)
  2. 一趟中找到最小值后,按从小到大顺序放到前排
  3. 重复第二步,直至遍历完成

3 . 代码实现

c 复制代码
// 选择排序函数
void selectionSort(int arr[], int n) {
    int i, j, minIndex, temp;
    
    // 外层循环控制未排序部分的起始位置
    for (i = 0; i < n - 1; i++) {
        minIndex = i; // 假设当前位置的元素是最小的

        // 内层循环在未排序部分中找到最小元素的索引
        for (j = i + 1; j < n; j++) {
            if (arr[j] < arr[minIndex]) {
                minIndex = j;
            }
        }

        // 交换找到的最小元素与当前位置元素
        temp = arr[i];
        arr[i] = arr[minIndex];
        arr[minIndex] = temp;
    }
}

4 . 时间复杂度

O ( n 2 ) O(n²) O(n2)

5 . 总结

选择排序适合用在数据量不多的场景,这个算法不需要借助过多的栈内存来完成,对系统的消耗多数体现在时间上的消耗,若是追求稳定性,对时间复杂度要求不高,这个算法是推荐的,谢谢观看。

技术交流群 : 745662457

群内专注 - 问题答疑,技术研究

相关推荐
王老师青少年编程2 分钟前
csp信奥赛c++中的递归和递推研究
c++·算法·递归·递推·csp·信奥赛
三佛科技-1873661339710 分钟前
LPK8717省外围无需启动电阻,12W自供电PSR控制芯片恒压恒流方案
单片机·嵌入式硬件
Bczheng114 分钟前
五.serialize.h中的CDataStream类
算法·哈希算法
小O的算法实验室15 分钟前
2025年SEVC,考虑组件共享的装配混合流水车间批量流调度的多策略自适应差分进化算法,深度解析+性能实测
算法·论文复现·智能算法·智能算法改进
汀、人工智能18 分钟前
[特殊字符] 第36课:柱状图最大矩形
数据结构·算法·数据库架构·图论·bfs·柱状图最大矩形
陶瓷好烦24 分钟前
智能编码助手:VSCode+Keil+Kilo Code打造自然语言编程环境
vscode·stm32·单片机
List<String> error_P25 分钟前
蓝桥杯最后冲刺(三)
算法
quintin-lee26 分钟前
Postgres 内核:从入门到“入土” (三) —— Page 结构:数据是如何在磁盘上“躺平”的
c语言·数据库·postgresql·数据库架构
样例过了就是过了35 分钟前
LeetCode热题100 跳跃游戏
c++·算法·leetcode·贪心算法·动态规划
无限进步_39 分钟前
【C++&string】寻找字符串中第一个唯一字符:两种经典解法详解
开发语言·c++·git·算法·github·哈希算法·visual studio