码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 选择排序超详细讲解C语言


    文章目录

    • 算法步骤
    • 动图演示
    • 静图演示
    • 代码实现
      • 普通
      • 升级
    • 复杂度、稳定性分析

    选择排序是一种简单直观的排序算法,无论数据是否有序,该排序的时间复杂度恒为 O ( N 2 ) O(N^{2}) O(N2),所以用该排序时,数据量越小越好。

    算法步骤

    首先在未排序序列中找到最小的(升序)元素,放在未排序序列的起始位置,然后再从剩下的未排序序列中找到最小的(升序)元素,放在未排序序列的起始位置,以此类推。

    动图演示

    img

    静图演示

    image-20220828153009022

    代码实现

    普通

    void SelectSort(int* a, int n){
        for(int i = 0; i < n - 1; i++){
          	//在未排序序列中找最小的元素
            int minIndex = i;
            for(int j = i + 1; j < n; j++){
                if(a[minIndex] > a[j]){
                    minIndex = j;//minIndex始终是最小元素的下标
                }
            }
            Swap(&a[minIndex], &a[i]);//将最小元素和首元素交换
        }
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12

    升级

    上面的是每次循环只找一个最小的,将最小的放首位后,序列向右收缩;

    而现在的升级版本是每次循环找一个最小的和一个最大的,将最小的放首位,最大的放末位,序列向中间收缩。

    然后

    void SelectSort(int* a, int n){
        int left = 0;
        int right = n - 1;
        while(left < right){
            int minIndex = left;
            int maxIndex = left;
            for(int i = left + 1; i <= right; i++){
                if(a[minIndex] > a[i]){
                    minIndex = i;
                }
                if(a[maxIndex < a[i]]){
                    maxIndex = i;
                }
            }
            Swap(&a[minIndex], &a[left]);
            if(maxIndex == left){
                maxIndex = minIndex;
            }
            Swap(&a[maxIndex], &a[right]);
            left++;
            right--;
        }
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23

    复杂度、稳定性分析

    1. 时间复杂度

      假设有N个数据

      不论数据是否有序,在排第1个数据时必定会比较N-1次,排第2个数据时必定会比较N-2次,所以总的比较次数为 1 + 2 + 3 + . . . + ( N − 1 ) 1 + 2 + 3+...+(N-1) 1+2+3+...+(N−1),等差数列求和,结果为 N 2 / 2 N^{2}/2 N2/2,时间复杂度为 O ( N 2 ) O(N^{2}) O(N2)。

    2. 空间复杂度

      仅仅使用了常数个辅助单元,空间复杂度是O(1);

    3. 稳定性

      举个例子,序列6 8 6 2 7, 第一遍选择,第一个6会和2交换,那么原序列中2个6的相对前后顺序就被破坏了,

      所以是不稳定的。

  • 相关阅读:
    JVM GC算法总结
    基于Spark封装的二次开发工程edata-base,介绍
    “后Optane时代”的替代存储方案有哪些?
    C#范围运算符
    给大家免费发布几款苹果CMSv10模板影视主题,附带教程和演示截图
    遥感影像正射矫正及高分二号遥感影像获取
    软件工程毕业设计课题(84)微信小程序毕业设计PHP物业维修报修小程序系统设计与实现
    微服务框架 SpringCloud微服务架构 21 RestClient 操作文档 21.5 批量导入文档
    安装Zookeeper以及Kafka(CentOS7)
    QSS样式表的使用
  • 原文地址:https://blog.csdn.net/qq_67569905/article/details/126574333
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号