C#核心知识回顾——19.插入排序

1.插入排序的基本原理

871542639
两个区域
排序区 未排序区
用一个索引值做分水岭
未排序区元素
与排序区元素比较
插入到合适位置
直到未排序区清空

cs 复制代码
int[] arr = { 8, 6, 7, 2, 9, 4 };
        //第一步
        //能取出未排序区的所有元素进行比较
        //i=1的原因:默认第一个元素就在排序区
        for (int i = 1; i < arr.Length; i++)
        {
            //第二步
            //每一轮
            //1.取出排序区的最后一个元素索引
            int sortIndex = i - 1;
            //2.取出未排序区的第一个元素
            int noSortNum = arr[i];
            //第三步
            //在未排序区进行比较
            //移动位置
            //确定插入索引
            //循环停止条件:
            //1.发现排序区所有元素比较完
            //2.发现排序区元素不满足条件
            while (sortIndex >= 0 && arr[sortIndex]>noSortNum)
            {
                //只要进了循环,证明满足条件
                //排序区元素需要往后退一格
                arr[sortIndex + 1] = arr[sortIndex]; 
                //移动到排序区前一个位置继续比较
                --sortIndex;
            }
            //最终插入数字
            //循环只是确认位置,循环结束后最终插入对应位置
            arr[sortIndex + 1] = noSortNum;
        }
总结:

为什么有两层循环

第一层循环:一次取出未排序区的元素进行排序

第二层循环:找到想要插入的位置

为什么第一层循环从1开始遍历

插入排序的关键是分两个区域

已排序区和未排序区

默认第一个元素在已排序区

为什么使用while循环

满足条件才比较

否则证明插入位置已确定

不需要继续循环

为什么可以直接往后移位置

每轮未排序数已记录

最后一个位置不怕丢

为什么确定位置后,是放在sort Index+1的位置

当循环停止时,插入位置应该是停止循环的索引1处

基本原理

两个区域

用索引值来区分

未排序区与排序区

元素不停比较

找到合适位置

插入当前元素

套路写法

两层循环

一层获取未排序区元素

一层找到合适插入位置

注意事项

默认开头已排序

第二层循环外插入

相关推荐
她说彩礼65万1 小时前
C# 代理模式
开发语言·c#·代理模式
Hody913 小时前
【XR开发系列】2025 年 XR 开发入门,我该选择 Unity 还是 Unreal Engine?
unity·xr·虚幻
张人玉4 小时前
TCP 的三次握手和四次挥手
网络·tcp/ip·c#
曹牧4 小时前
C#:三元运算符
开发语言·c#
DvLee10245 小时前
UnityGLTF 材质创建与赋值流程
unity·材质
m0_748248027 小时前
C++与C#布尔类型深度解析:从语言设计到跨平台互操作
c++·stm32·c#
HahaGiver6668 小时前
从0到1做一个“字母拼词”Unity小游戏(含源码/GIF)- 字母拼词正确错误判断
unity·游戏引擎·游戏程序
LeonDL1688 小时前
【通用视觉框架】基于C#+VisionPro开发的视觉框架软件,全套源码,开箱即用
人工智能·c#·visionpro·通用视觉框架·机器视觉框架·视觉框架软件·机器视觉软件
一抓掉一大把9 小时前
RuoYi .net-实现商城秒杀下单(redis,rabbitmq)
redis·mysql·c#·rabbitmq·.net
睡前要喝豆奶粉10 小时前
在.NET Core Web Api中使用阿里云OSS
阿里云·c#·.netcore