希尔排序

希尔排序是一种改进的插入排序算法,它通过将原始数据分成多个子序列来改善插入排序的性能,每个子序列的元素间隔为 d(增量)。随着算法的进行,d 逐渐减小,最终减为 1,此时整个序列就被排序好了。

c++代码:

cpp 复制代码
// 希尔排序函数
void shell_sort(std::vector<int>& nums) {
    int temp = 0;
    int n = nums.size();
    // 初始增量为数组长度的一半,逐步缩小增量
    for (int d = n / 2; d >= 1; d /= 2) {
        // 对每个子序列进行插入排序,sub_start表示每个子序列的首元素索引
        for (int sub_start = 0; sub_start < d; sub_start++) {
            // 对当前子序列进行插入排序
            for (int i = sub_start + d; i < n; i += d) {
                if (nums[i] < nums[i - d]) {
                    temp = nums[i];
                    int j;
                    // 移动元素,找到插入位置
                    for (j = i - d; j >= 0 && nums[j] > temp; j -= d) {
                        nums[j + d] = nums[j];
                    }
                    // 插入元素
                    nums[j + d] = temp;
                }
            }
        }
    }
}

c语言代码:

cpp 复制代码
// 希尔排序函数
void shell_sort(int nums[],int n) {
    int temp = 0;
    // 初始增量为数组长度的一半,逐步缩小增量
    for (int d = n / 2; d >= 1; d /= 2) {
        // 对每个子序列进行插入排序,sub_start表示每个子序列的首元素索引
        for (int sub_start = 0; sub_start < d; sub_start++) {
            // 对当前子序列进行插入排序
            for (int i = sub_start + d; i < n; i += d) {
                if (nums[i] < nums[i - d]) {
                    temp = nums[i];
                    int j;
                    // 移动元素,找到插入位置
                    for (j = i - d; j >= 0 && nums[j] > temp; j -= d) {
                        nums[j + d] = nums[j];
                    }
                    // 插入元素
                    nums[j + d] = temp;
                }
            }
        }
    }
}

总结

|-------|----------------|
| 时间复杂度 | 未知,但优于直接插入排序 |
| 空间复杂度 | O(1) |
| 稳定性 | 不稳定 |
| 适用性 | 只可用于顺序表,不可用于链表 |
[希尔排序性质]

相关推荐
乌萨奇也要立志学C++9 小时前
【洛谷】队列相关经典算法题详解:模板队列、机器翻译、海港
算法
YuTaoShao10 小时前
【LeetCode 热题 100】49. 字母异位词分组
算法·leetcode·哈希算法
aliedudu11 小时前
决策树概念与原理
算法·决策树·机器学习
程序员Xu12 小时前
【LeetCode热题100道笔记】腐烂的橘子
笔记·算法·leetcode
天选之女wow12 小时前
【代码随想录算法训练营——Day4】链表——24.两两交换链表中的节点、19.删除链表的倒数第N个节点、面试题02.07.链表相交、142.环形链表II
数据结构·算法·leetcode·链表
胡萝卜3.012 小时前
数据结构初阶:树的相关性质总结
数据结构·二叉树·性质·二叉树的性质
KarrySmile12 小时前
Day12--HOT100--23. 合并 K 个升序链表,146. LRU 缓存,94. 二叉树的中序遍历
数据结构·链表·二叉树·递归·hot100·lru·灵茶山艾府
THMAIL13 小时前
量化基金从小白到大师 - 金融数据获取大全:从免费API到Tick级数据实战指南
人工智能·python·深度学习·算法·机器学习·金融·kafka
纪元A梦13 小时前
贪心算法应用:数字孪生同步问题详解
java·算法·贪心算法
纪元A梦13 小时前
贪心算法应用:食品生产线排序问题详解
算法·贪心算法