码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 数据结构之八大排序——简单选择排序



    目录

    一、排序过程

    二、代码

    三、性能及稳定性分析

    1.空间复杂度

    2.时间复杂度

    3.稳定性


    一、排序过程

    假设待排序的序列为L[1...n],第i趟排序是从L[i...n]中从i开始遍历选择一个关键字最小的元素与L(i)交换位置,每一趟排序可以确定一个元素的最终位置,经过n-1趟排序可使得排序表有序。

    简单选择排序

    二、代码

    1. public class SelectionSort {
    2. public static void main(String[] args) {
    3. int[] arr = {1, 7, 4, 9, 6, 7, 2, 5};
    4. System.out.print("排序前为:");
    5. for (int i : arr) {
    6. System.out.print(i + " ");
    7. }
    8. System.out.println();
    9. selection(arr);
    10. System.out.print("排序后为:");
    11. for (int i : arr) {
    12. System.out.print(i + " ");
    13. }
    14. }
    15. public static void selection(int[] arr) {
    16. for (int i = 0; i < arr.length - 1; i++) { //进行排序的趟数n-1趟
    17. int min = i; //假定每一趟第i个元素为最小元素
    18. for (int j = min + 1; j < arr.length; j++) { //在arr[i...n-1]中选择最小的元素
    19. if (arr[j] < arr[min]) { //判断元素是否小于arr[min]
    20. min = j; //如果在arr[i...n-1]中有比arr[min]小的元素就将其下标赋给min
    21. }
    22. }
    23. if (min != i) { //判断最小元素是否为第i个并对交换arr[i]arr[min]
    24. int temp = arr[min];
    25. arr[min] = arr[i];
    26. arr[i] = temp;
    27. }
    28. }
    29. }
    30. }

    选择排序的过程:

     

    结果: 

     

    三、性能及稳定性分析

    1.空间复杂度

    因为排序的整个过程中,仅在当前的数组中操作,没有使用另一个空数组,仅使用了常熟个辅助单元,因此时间复杂度为O(1)

    2.时间复杂度

    最好情况为起始序列有序,移动0次。但是元素之间的比较次数与序列的起始状态无关,始终是n(n-1)/2次。

    所以时间复杂度始终是O\left ( n^{2} \right )。

    3.稳定性

    由上图对简单选择排序的分析,红色的7开始在白色的7前面,在进行第二趟排序的时候红色的7被交换到后面。因此简单选择排序是一个不稳定的排序。


    ​

  • 相关阅读:
    以太网基础——DoIP报文类型
    关于I/O——内存与CPU与磁盘之间的关系
    【开发小记】elementUI面包屑跳到二级路由仍然保持父级导航栏高亮
    C语言-文件操作(最全)(二十一)
    笔试刷题Day—8
    【毕业设计源码】基于JAVA的微信小程序直播在线教育平台
    力扣 剑指 Offer 51. 数组中的逆序对
    Aspose.total帮助某软件公司程序实现高效自定义文档操作
    ios面试准备 - objective-c篇
    mac苹果笔记本应用程序在哪?有什么快捷方式吗?
  • 原文地址:https://blog.csdn.net/weixin_55166132/article/details/125838644
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | 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号