排序算法---希尔排序

1. 基本思想

希尔排序是插入排序的一种,它与直接插入排序不同的是,它会优先比较距离较远的元素,因此希尔排序又被称为"缩小增量排序"。希尔排序的实现思路是:先将整个待排序的记录序列分割成为若干子序列 分别进行直接插入排序,待整个序列中的记录"基本有序"时,再对全体记录进行依次直接插入排序。

2. 实现逻辑

(1)首先选取一个步长gap,通常是数组长度的一半,向上取整和向下取整都可以

(2)所有距离为gap的倍数的记录放在同一个组中,在各组内进行直接插入排序。

(3)改变步长 gap = gap/2, 重复操作,直至完全有序

3. 案例:

对数组 [9,1,2,5,7,4,8,6,3,5] 进行排序

3.1 流程图

3.2 实现代码

javascript 复制代码
        function shellSort(arr) {
            let len = arr.length
            let count = 0
            for (let gap = parseInt(len / 2); gap > 0; gap = parseInt(gap / 2)) {
                // 外层循环将数组分成若干组
                for (let i=gap; i<len; i++) {  
                    // 内层遍历每组中所有的元素,对每一组进行插入排序
                    for (let j=i-gap; j>=0; j-=gap) {
                        if (arr[j] > arr[j+gap]){
                            let temp = arr[j]
                            arr[j] = arr[j+gap]
                            arr[j+gap] = temp
                        }
                    }
                }

                console.log(`希尔排序第${++count}轮结束后,数组变为:${arr}`)
            }
         }
         let arr = [9,1,2,5,7,4,8,6,3,5]
         shellSort(arr)

3.3 结果

4. 复杂度分析

4.1 时间复杂度

4.2 空间复杂度

4.3 稳定性

我们在分布对数组进行排序的时候,很有可能将两个相同值的元素的相对位置进行改变,所以希尔排序是不稳定的排序算法

相关推荐
weixin_4577600016 小时前
Python 数据结构
数据结构·windows·python
明洞日记17 小时前
【数据结构手册002】动态数组vector - 连续内存的艺术与科学
开发语言·数据结构·c++
fashion 道格17 小时前
数据结构实战:深入理解队列的链式结构与实现
c语言·数据结构
xxxxxxllllllshi18 小时前
【LeetCode Hot100----14-贪心算法(01-05),包含多种方法,详细思路与代码,让你一篇文章看懂所有!】
java·数据结构·算法·leetcode·贪心算法
铁手飞鹰19 小时前
二叉树(C语言,手撕)
c语言·数据结构·算法·二叉树·深度优先·广度优先
[J] 一坚20 小时前
深入浅出理解冒泡、插入排序和归并、快速排序递归调用过程
c语言·数据结构·算法·排序算法
司铭鸿21 小时前
祖先关系的数学重构:从家谱到算法的思维跃迁
开发语言·数据结构·人工智能·算法·重构·c#·哈希算法
yk0820..21 小时前
测试用例的八大核心要素
数据结构
北京地铁1号线1 天前
数据结构:堆
java·数据结构·算法
得物技术1 天前
从数字到版面:得物数据产品里数字格式化的那些事
前端·数据结构·数据分析