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

一、介绍

插入排序就是将前两个元素排好,再将第三个元素通过与前边的元素比较后插入适当的位置,再将第四个元素插入,不断重复插入与前边元素比较的操作,直到将元素都排列好。

演示如下:

视频演示:

直接插入排序演示_哔哩哔哩_bilibili直接插入排序演示 视频播放量 80、弹幕量 0、点赞数 3、投硬币枚数 0、收藏人数 0、转发人数 1, 视频作者 浅陌95sss, 作者简介 记录自己的学习成果,分享自己的快乐,相关视频:冒泡排序演示,希尔排序,选择排序演示,快速排序,学习记录--设计模式之命令模式,学习记录--网格系统,学习记录--BFS寻路算法,排行榜模拟,简单的同步Demo,xlua热更新框架https://www.bilibili.com/video/BV1hT4y1C7Ja/?spm_id_from=333.999.0.0运行代码:

cs 复制代码
 void InsertSort(int[] data)
 {
     int preIdx, current = 0;
     for (int i = 1; i < data.Length; i++)
     {
         //储存当前索引值的前边的索引值
         preIdx = i - 1;
         //储存当前要比较的数值
         current= data[i];

         //判断前边的数值是否比当前数值大,如果大说明当前值还需要往前移动,也就是preIdx对应的值
         //需要向后移动,否则在preIdx的后一个索引值preIdx+1处赋值(因为所有值在比较时都往后移动了)
         while (preIdx >= 0 && data[preIdx] > current)
         {
             data[preIdx + 1] = data[preIdx];
             preIdx--;
         }
         data[preIdx + 1] = current;
     }
 }
相关推荐
折哥的程序人生 · 物流技术专研17 小时前
Java面试85题图解版 · 特别篇:2026后端高频面试题复盘(算法底层逻辑+高并发架构设计全解析,附Java实战代码)
java·网络·数据库·算法·面试
想吃火锅100518 小时前
【leetcode】14.最长公共前缀js
算法·leetcode·职场和发展
云絮.19 小时前
数据库操作
数据库·mysql·算法·oracle
小林ixn19 小时前
LeetCode 206. 反转链表(迭代 + 递归详解)
算法·leetcode·链表
凡人叶枫20 小时前
Effective C++ 条款17:以独立语句将 newed 对象置入智能指针
java·linux·开发语言·c++·算法
菜鸟‍21 小时前
LeetCode 1 27 和 704 || 两数之和 移除元素 二分查找
算法·leetcode·职场和发展
退休倒计时1 天前
【每日一题】LeetCode 142. 环形链表 II TypeScript
算法·leetcode·链表·typescript
popcorn_min1 天前
Digits 手写数字识别:随机森林多分类 + 像素级特征热力图
算法·随机森林·分类
liulilittle1 天前
拥塞控制:排水终止的两种决策:OR 与 AND
网络·tcp/ip·计算机网络·算法·信息与通信·tcp·通信
花间相见1 天前
【LeetCode02】—— 两数之和:哈希表入门经典详解
数据结构·散列表