0

0

c++如何实现希尔排序_c++改进的插入排序算法【进阶】

冰火之心

冰火之心

发布时间:2026-02-17 17:02:03

|

286人浏览过

|

来源于php中文网

原创

希尔排序的核心是分组插入,关键在间隔序列选择和组内有序性传递;需用gap步长跳跃比较交换,而非简单套用插入排序;knuth等优化序列可避免o(n²)退化,且算法不稳定。

c++如何实现希尔排序_c++改进的插入排序算法【进阶】

希尔排序的核心是分组插入,不是“改进插入排序”的字面理解

很多人误以为希尔排序只是把 insertion_sort 套个外层循环就完事了,其实关键在「间隔序列」的选择和「组内有序性」的传递。直接套用普通插入排序逻辑会导致每组内部排完后,跨组无序性被忽略,最终结果错误。

正确做法是:对每个间隔 gap,以该步长为单位,对所有偏移量为 0,1,...,gap-1 的子序列分别做插入排序——但不是独立排序,而是用同一轮 for 循环驱动,靠内层 while 向前跳跃 gap 位置比较交换。

  • 常见错误:用 for (int i = gap; i 然后只对 <code>i 所在子序列做一次插入,漏掉其他起始位置(如 i=0,1,...,gap-1
  • 正确结构:外层控制 gap 缩减,中层 igapn-1,内层 ji 开始,每次减 gap,直到 j 或 <code>arr[j] >= arr[j-gap]
  • 性能影响:gap 序列决定最坏时间复杂度。用 gap = gap / 2(Knuth 序列更优)比暴力除 2 更稳定;避免使用 gap = 1 作为唯一终态前的最后一步,否则退化成纯插入排序

如何选 gap 序列?别用简单的 n/2, n/4, …

原始 Shell 提出的 gap = n/2, n/4, ..., 1 在某些数据下会退化到 O(n²),比如已按奇偶分块有序的数组。现代实践中推荐 Knuth 序列:gap = 3 * gap + 1 生成后倒序使用,或 Sedgewick 序列(4^k + 3×2^(k−1) + 1),它们能更好打破局部有序性。

实操建议:

立即学习C++免费学习笔记(深入)”;

Toolify.ai
Toolify.ai

Toolify.ai是一个专门收集、评测AI工具和服务的网址导航站

下载
  • 预生成 gap 序列时,先从 1 开始正向生成直到 > n,再逆序遍历(确保首项 ≤ n-1
  • 避免在循环中实时计算 gap /= 2,容易因整数截断过早变成 0(如 gap=11/2==0),导致死循环或越界
  • C++ 中可用 std::vector<int></int> 存 gap,或用 while 预算最大 gap 再递减,比递归生成更可控

原地排序下,swap 操作必须支持 gap 步长移动

标准插入排序中,swap(arr[j], arr[j-1]) 是相邻交换;希尔排序里必须改成 swap(arr[j], arr[j-gap]),且 j 的更新也要是 j -= gap。漏掉这个细节,算法就变成多个独立插入排序,无法实现“远距离元素提前靠近”的效果。

示例片段(关键部分):

for (int gap = max_gap; gap > 0; gap /= 2) {
    for (int i = gap; i < n; ++i) {
        int temp = arr[i];
        int j = i;
        while (j >= gap && arr[j - gap] > temp) {
            arr[j] = arr[j - gap]; // 注意这里是 j-gap,不是 j-1
            j -= gap;              // 步长是 gap,不是 1
        }
        arr[j] = temp;
    }
}
  • 注意:arr[j] = temp 不在 while 内,避免覆盖未比较位置
  • 比较条件用 arr[j - gap] > temp 而非 arr[j] > arr[j-gap],这是标准插入式写法,减少重复读取
  • 如果元素类型不支持 operator>(如自定义结构体),需传入比较函数对象,且要确保它适用于任意间隔下的元素对

稳定性?别指望希尔排序是稳定的

希尔排序本质不稳定——相同值的元素可能因不同 gap 轮次被跨距交换,相对位置不可逆。例如数组 [5a, 2, 5b, 1](a/b 表示相同值但不同实例),在 gap=25a5b 不比较,但在 gap=15b 可能被移到 5a 前面。

如果你需要稳定排序且又想利用分组思想,应改用归并或带索引的计数排序,而不是强行改造希尔排序。

实际工程中,除非明确要求原地、平均 O(n^1.3) 且数据规模中等(几万以内)、对稳定性无感,否则直接用 std::sort 更稳妥——它底层是 introsort,兼顾最坏性能与常数因子。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
sort排序函数用法
sort排序函数用法

sort排序函数的用法:1、对列表进行排序,默认情况下,sort函数按升序排序,因此最终输出的结果是按从小到大的顺序排列的;2、对元组进行排序,默认情况下,sort函数按元素的大小进行排序,因此最终输出的结果是按从小到大的顺序排列的;3、对字典进行排序,由于字典是无序的,因此排序后的结果仍然是原来的字典,使用一个lambda表达式作为key参数的值,用于指定排序的依据。

401

2023.09.04

while的用法
while的用法

while的用法是“while 条件: 代码块”,条件是一个表达式,当条件为真时,执行代码块,然后再次判断条件是否为真,如果为真则继续执行代码块,直到条件为假为止。本专题为大家提供while相关的文章、下载、课程内容,供大家免费下载体验。

103

2023.09.25

golang结构体相关大全
golang结构体相关大全

本专题整合了golang结构体相关大全,想了解更多内容,请阅读专题下面的文章。

344

2025.06.09

golang结构体方法
golang结构体方法

本专题整合了golang结构体相关内容,请阅读专题下面的文章了解更多。

198

2025.07.04

string转int
string转int

在编程中,我们经常会遇到需要将字符串(str)转换为整数(int)的情况。这可能是因为我们需要对字符串进行数值计算,或者需要将用户输入的字符串转换为整数进行处理。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

750

2023.08.02

int占多少字节
int占多少字节

int占4个字节,意味着一个int变量可以存储范围在-2,147,483,648到2,147,483,647之间的整数值,在某些情况下也可能是2个字节或8个字节,int是一种常用的数据类型,用于表示整数,需要根据具体情况选择合适的数据类型,以确保程序的正确性和性能。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

572

2024.08.29

c++怎么把double转成int
c++怎么把double转成int

本专题整合了 c++ double相关教程,阅读专题下面的文章了解更多详细内容。

234

2025.08.29

C++中int的含义
C++中int的含义

本专题整合了C++中int相关内容,阅读专题下面的文章了解更多详细内容。

210

2025.08.29

pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法
pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法

本专题系统整理pixiv网页版官网入口及登录访问方式,涵盖官网登录页面直达路径、在线阅读入口及快速进入方法说明,帮助用户高效找到pixiv官方网站,实现便捷、安全的网页端浏览与账号登录体验。

283

2026.02.13

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
C# 教程
C# 教程

共94课时 | 9.6万人学习

C 教程
C 教程

共75课时 | 4.8万人学习

C++教程
C++教程

共115课时 | 18.1万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号