c++希尔排序

希尔排序(Shell Sort)是一种插入排序的改进版本,它是非稳定排序算法。希尔排序的基本思想是将待排序的元素分成若干个小组,对每组进行插入排序,然后逐步减小增量,继续按组进行插入排序操作,直至增量为1,最后对整个序列进行一次插入排序。

以下是一个使用 C++ 实现的希尔排序示例:

cpp 复制代码
#include <iostream>
#include <vector>

void shellSort(std::vector<int>& arr) {
    int n = arr.size();
    
    for (int gap = n / 2; gap > 0; gap /= 2) {
        for (int i = gap; i < n; i++) {
            int temp = arr[i];
            int j;
            for (j = i; j >= gap && arr[j - gap] > temp; j -= gap) {
                arr[j] = arr[j - gap];
            }
            arr[j] = temp;
        }
    }
}

int main() {
    std::vector<int> arr = {12, 34, 54, 2, 3};
    
    std::cout << "Original array:";
    for (int num : arr) {
        std::cout << " " << num;
    }
    std::cout << std::endl;
    
    shellSort(arr);
    
    std::cout << "Sorted array:";
    for (int num : arr) {
        std::cout << " " << num;
    }
    std::cout << std::endl;
    
    return 0;
}

在这个示例中,我们首先定义了一个 shellSort 函数用于实现希尔排序,然后在 main 函数中初始化一个整数数组,调用 shellSort 函数对数组进行排序,并输出排序前后的数组内容。希尔排序通过不断缩小增量的方式,可以更有效地减少逆序对的数量,提高排序效率。

相关推荐
_Twink1e38 分钟前
[算法竞赛]九、C++标准模板库STL常用容器大全
开发语言·c++
bu_shuo1 小时前
c++中对数组求和
开发语言·c++
elseif1231 小时前
【Markdown】指南(上)
linux·开发语言·前端·javascript·c++·笔记
星辰徐哥1 小时前
C++网络编程:TCP服务器与客户端的实现
网络·c++·tcp/ip
·心猿意码·2 小时前
C++ volatile 与 std::atomic 底层语义剖析
c++
Tanecious.2 小时前
蓝桥杯备赛:Day1-奖学金
c语言·c++·蓝桥杯
汉克老师2 小时前
GESP2025年6月认证C++三级( 第三部分编程题(1、奇偶校验)
c++·算法·gesp三级·gesp3级·按位操作
CoderCodingNo2 小时前
【GESP】C++八级考试大纲知识点梳理 (8) 算法优化技巧
开发语言·c++
十年编程老舅2 小时前
窥探内核心脏:深入解析 proc 虚拟文件系统
linux·服务器·数据库·c++·linux内核·文件系统·读写锁
xiaoye-duck3 小时前
【C++:哈希表】从哈希冲突到负载因子:深入探索开放定址与链地址法的核心机密
数据结构·c++·散列表