码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 经典算法之插入排序(InsertionSort)


    在这里插入图片描述

    活动地址:CSDN21天学习挑战赛

    插入排序

    • 一、算法介绍
    • 二、算法思想
    • 三、算法原理
    • 四、动图演示
    • 五、代码实现
    • 六、算法分析
      • 6.1 时间复杂度
      • 6.2 空间复杂度
    • 写在最后

    一、算法介绍

    插入排序,也称为直接插入排序。插入排序是简单排序中效率最好的一种,它也是学习其他高级排序的基础,比如希尔排序/快速排序,所以非常重要,而它相对于选择排序的优点就在于比较次数几乎是少了一半。

    二、算法思想

    每次将待排序的元素插入到已排序的序列中,直至全部插入完成。

    三、算法原理

    • 把所有元素分为两个序列,将第一待排序序列第一个元素看做一个有序序列,把第二个元素到最后一个元素当成是未排序序列。

    • 从未排序序列中的第一个元素开始,向已排序的序列中插入

    • 倒序遍历已排序序列,依次和待插入的元素比较,找到一个小于或等于待插入的元素,插入到该元素后面,其余元素向后移动一位

    四、动图演示

    在这里插入图片描述

    五、代码实现

    核心代码

    public class InsertionSort {
        //  插入排序
        public static void sort(Comparable[] a){
           for (int i = 1;i < a.length;i++){
               for (int j = i;j > 0;j--){
                   //比较索引j处的值与索引j-1处的值,如果j-1索引处的值大,则交换数据,反之,则找到了合适的位置,退出循环
                   if (greater(a[j - 1],a[j])){
                       swap(a,j - 1,j);
                   }else{
                       break;
                   }
               }
           }
        }
        //比较 v 是否大于 w
        public static boolean greater(Comparable v,Comparable w){
            return v.compareTo(w) > 0;
        }
        //数组元素交换位置
        private static void swap(Comparable[] a,int i,int j){
            Comparable temp;
            temp = a[i];
            a[i] = a[j];
            a[j] = temp;
        }
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26

    方法调用

    public class InsertionSortTest {
        public static void main(String[] args) {
            Integer[] arr = {3,44,38,5,47,15,36,26,27};
            InsertionSort.sort(arr);
            System.out.println(Arrays.toString(arr));
        }
    }
    //排序前:{3,44,38,5,47,15,36,26,27}
    //排序后:{3,5,15,26,27,36,38,44,47}
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9

    六、算法分析

    6.1 时间复杂度

    当待排序的 n 个元素是正序排列时,是排序的最佳情况,只需要比较(n-1)次,时间复杂度是O(n);最坏的情况是该序列是反序排列,此时就需要比较n(n-1)/2次,时间复杂度为 O(n²)。

    插入排序的平均时间复杂度为 O(n²)

    6.2 空间复杂度

    插入排序的空间复杂度为常数阶O(1)

    写在最后

    在这里插入图片描述

  • 相关阅读:
    v74.01 鸿蒙内核源码分析(编码方式篇) | 机器指令是如何编码的 | 百篇博客分析OpenHarmony源码
    oraccle数据库常用函数
    数据结构(2-5~2-8)
    NumPy 舍入小数、对数、求和和乘积运算详解
    【安泰ATX-3000】线束测试仪:新能源商用车高压绝缘测试分享
    LeetCode_前缀树_排序_哈希集合_中等_720.词典中最长的单词
    直击固定资产管理痛点,让企业轻松管理海量固定资产
    Docker从认识到实践再到底层原理(五)|Docker镜像
    【Git】Git 基础
    定时任务(二)
  • 原文地址:https://blog.csdn.net/weixin_52986315/article/details/126152319
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | 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号