当前位置: 首页 > news >正文

排序算法之——直接插入排序

直接插入排序——以升序排列为例

  • 1.1基本思想
  • 1.2动态图示感知
  • 1.3静态图示详解
  • 1.4代码实现
  • 1.5时间复杂度
    • 1.5.1最好情况
    • 1.5.2最差情况
  • 1.6空间复杂度
  • 1.7稳定性
    • 1.7.1一个小问题

1.1基本思想

把待排序的记录按其关键码值的大小逐个插入到一个已经排好序的有序序列中,直到所有的记录插入完为止,得到一个新的有序序列 。实际中我们玩扑克牌时,就用了插入排序的思想。
在这里插入图片描述

1.2动态图示感知

在这里插入图片描述

1.3静态图示详解

以一组待排序数据:5 3 1 6 9 9为例:
在这里插入图片描述

1.4代码实现

   public static void insertSort(int[] array){for(int i = 1;i < array.length;i++){int tmp = array[i];//初始化tmp的值int j = i - 1;for( ;j >= 0;j--){//这里带不带等号,会影响排序的稳定性if(array[j] > tmp){array[j+1] = array[j];}else{break;}}array[j + 1] = tmp;}}

1.5时间复杂度

1.5.1最好情况

当待排序数组已经是一个升序排列的数组时,此时时间复杂度最低。因为对于i遍历的每一个值,j无需向左遍历,此时只相当于i遍历了一遍数组(确切的说,是遍历了除第一个元素外的数组),因此时间复杂度为O(n)
在这里插入图片描述

1.5.2最差情况

当待排序数组已经是一个降序排列的数组时,此时时间复杂度最高。因为对于i遍历的每一个值,j需要向左遍历直到-1,因此整个排休的时间复杂度为O(n^2)
在这里插入图片描述
特点:由以上分析可知,待排序的数据越“有序”,直接插入排序算法的时间复杂度越低。这一特点可以用到某些排序算法的优化上,比如快速排序。

1.6空间复杂度

整个排序过程只创建了常数个临时变量,因此空间复杂度为O(1)

1.7稳定性

1.2图示详解中,原始数组中的数据9和9,在排序后相对位置没有发生变化,因此直接插入排序是稳定的排序

1.7.1一个小问题

如果将原有代码中的这句:

if(array[j] > tmp){array[j+1] = array[j];
}else{break;
}

改为:

if(array[j] >= tmp){array[j+1] = array[j];
}else{break;
}

即将判断条件的 “>” 改为 “>=”
原有的直接插入排序还是稳定的吗?
答:不稳定。

图示说明如下(对比1.3静态图示详解的最后两步):
在这里插入图片描述
所以直接插入排序是稳定的还是不稳定的呢?
前面已经说明了直接插入排序是稳定的排序。之所以会出现把 > 修改成 >=,原有的排序由稳定变为不稳定的情况,是因为:一个本身就不稳定的排序,是不可能是现成稳定的排序的;而一个本身稳定的排序,是可以实现为不稳定的排序的。

http://www.lryc.cn/news/303043.html

相关文章:

  • 突出最强算法模型——回归算法 !!
  • 云数据库 Redis 性能深度评测(阿里云、华为云、腾讯云、百度智能云)
  • Android---Retrofit实现网络请求:Java 版
  • 使用静态CRLSP配置MPLS TE隧道
  • gentoo安装笔记
  • Git如何使用 五分钟快速入门
  • FreeRTOS学习笔记——(FreeRTOS临界段代码保护及调度器挂起与恢复)
  • 箱形理论在交易策略中的实战应用与优化
  • MinIO 和 Apache Tika:文本提取模式
  • c编译器学习05:与chibicc类似的minilisp编译器(待续)
  • 手撕qsort函数
  • 项目在linux上的简单部署
  • MySQL安装教程(详细版)
  • Linux platform tree下的单总线驱动程序设计(DHT11)
  • 自研爬虫框架的经验总结(理论及方法)
  • 配置基于 AWS CRT 的 HTTP 客户端
  • 挑战杯 基于LSTM的天气预测 - 时间序列预测
  • 我为什么不喜欢关电脑?
  • Unity【角色/摄像机移动控制】【1.角色移动】
  • Oracle12cR2之Job定时作业调度器详解
  • python自学...
  • Message Pack 协议详解及应用
  • 智慧社区管理系统:构建未来的生活模式
  • Rocky 8.9 Kubespray v2.24.0 在线部署 kubernetes v1.28.6 集群
  • 新版AI系统ChatGPT源码支持GPT-4/支持AI绘画去授权
  • 学习鸿蒙基础(5)
  • Tuxera NTFS2024最新中文版支持M1/M2/M3苹果全系机型
  • 【Python】OpenCV-图片添加水印处理
  • Milvus数据库介绍
  • notepad++的下载与使用