数据结构 -- 插入排序(直接插入排序和希尔排序)

插入排序

算法思想

每次将⼀个待排序的记录按其关键字大小插入到前面已排好序的子序列中,直到全部记录插入完成。

代码实现
c 复制代码
void InsertSort(int A[],int n){
    int i,j,temp;
    for(i = 1;i<n;i++){
        if(A[i]<A[i-1]){
            temp = A[i];			//用temp暂存A[i]
            for(j=i-1;j>=0&&A[j]>temp;--j)		//检查所有前面已经排好序的元素
                A[j+1]=A[j];				//所有大于temp的元素都往后挪一位
            A[j+1]=temp;					//复制到插入位置
        }
    }
}
代码实现(带哨兵)
c 复制代码
void Insert(A[],int n){
    int i,j;
    for(i = 2;i<=n;i++){
        if(A[i]<A[i-1]){
            A[0]=A[i];
            for(j=i-1;A[0]<A[j];--j)
                A[j+1]=A[j];
            A[j+1] = A[0];
        }
    }
}

优点:不需要每轮循环都判断一次j>=0

算法效率分析
时间复杂度 空间复杂度 稳定性
O(1) 主要来自对比关键字、移动 元素(若有n个元素 则需要 n-1 趟处理) 稳定
最好情况:每次只需要对比一次 不需要移动→O(n)
最坏情况:原本都是逆序排放的 → O(n2)
平均时间复杂度:O(n2)
优化 -- 折半插入排序

先用折半查找找到应该插入的位置,再移动元素

当low>high时折半查找停止,并将low之后的元素全部右移,并将A[0]复制到low所在位置

为了保证算法的稳定性,当A[mid]=A[0]时,应继续在mid所指的右边寻找插入位置

c 复制代码
void InsertSOrt(int A[],int n){
    iint i,j,low,high,mid;
    for(i=2;i<=n;i++){
        A[0]=A[i];
        low = 1;high = i-1;
        while(low<=high){
            mid = (low+high)/2;
            if(A[mid]>A[0]) high = mid-1;
            else low=mid+1;
        }
        for(j=i-1;j>=high+1;--j)
            A[j+1]=A[j];
        A[high+1]=A[0];
    }
}

比起"直接插入排序",比较关键字的次数减少了,但是移动元素的次数没变,整体来看时间复杂度仍未O(n2)

希尔排序

算法思想

先将待排序表分割成若干形如 L[i, i + d, i + 2d,..., i + kd] 的"特殊"子表,对各个子表分别进行直接插入排序。缩小增量d,重复上述过程,直到d=1为止。

......

c 复制代码
//希尔排序
void ShellSort(int A[],int n){
    int d,i,j;
    //A[0]只是暂存单元,不是哨兵,当j<=0时,插入位置已到
    for(i=d/2;d>=1;d=d/2)
        for(i=d+1;i<=n;++i)
            if(A[i]<A[i-d]){
                A[0]=A[i];
                for(j = i-d;j>0&&)
            }
}

目前无法用数学⼿段证明确切的时间复杂度 ,最坏时间复杂度为 O(n2),当n在某个范围内时,可达O(n1.3)

稳定性:不稳定

适⽤性:仅适⽤于顺序表,不适⽤于链表

相关推荐
小厂永远得不到的男人5 分钟前
基于 Spring Validation 实现全局参数校验异常处理
java·后端·架构
计算机编程小咖43 分钟前
《基于大数据的农产品交易数据分析与可视化系统》选题不当,毕业答辩可能直接挂科
java·大数据·hadoop·python·数据挖掘·数据分析·spark
艾莉丝努力练剑44 分钟前
【C语言16天强化训练】从基础入门到进阶:Day 7
java·c语言·学习·算法
老华带你飞1 小时前
校园交友|基于SprinBoot+vue的校园交友网站(源码+数据库+文档)
java·数据库·vue.js·spring boot·论文·毕设·校园交友网站
自强的小白2 小时前
学习Java24天
java·学习
Ashlee_code3 小时前
香港券商櫃台系統跨境金融研究
java·python·科技·金融·架构·系统架构·区块链
还梦呦3 小时前
2025年09月计算机二级Java选择题每日一练——第五期
java·开发语言·计算机二级
2501_924890523 小时前
商超场景徘徊识别误报率↓79%!陌讯多模态时序融合算法落地优化
java·大数据·人工智能·深度学习·算法·目标检测·计算机视觉
從南走到北4 小时前
JAVA国际版东郊到家同城按摩服务美容美发私教到店服务系统源码支持Android+IOS+H5
android·java·开发语言·ios·微信·微信小程序·小程序
qianmoq4 小时前
第04章:数字流专题:IntStream让数学计算更简单
java