Python数据结构与算法(15)---希尔排序

简介: Python数据结构与算法(15)---希尔排序

希尔排序


希尔排序,又称作Shell Sort,也叫缩小增量排序算法,是前文讲解的插入排序更高效的一种排序算法。


其原理是:在n个元素的列表里,取增量n/2。数列开始值与增量值的尾值进行比较,小的放前面,大的放后面;把增量的前后都比较一遍,然后增量数-1。


继续从头到尾进行比较,并调整大小;一直到增量等于1,就完成了所有列表元素的排序。至于增量规则可以自行定义。


图解写入排序

假设,又一个列表为[8,0,4,3,2,1]。具体原理步骤如下:


第1次,增量为3,那么需要进行3次循环。(每次循环2个数进行比较排序)


上面,首先对索引0到索引3的数值进行比较,然后比较索引1与索引4,最后比较索引2与索引5的值。


第2次,增量为2,那么需要进行2次循环。


接着,对索引0、索引2、与索引4的数值进行比较,然后比较索引1、索引3、索引5的数值。


第3次,增量为1,那么需要进行1次循环。


最后,对比索引0与索引1,索引1与索引2,索引2与索引3,索引3与索引4,索引4与索引5的各个数的值。就完成了最终的排序过程。这个过程就叫希尔排序。


实战:希尔排序

通过上面的举例,以及图解的分析,相信读者都能够看懂希尔排序的过程以及相对应的原理。下面,我们来用Python实现希尔排序,示例如下:

def shell_sort(my_list):
    n = len(my_list)
    if n == 1:
        return my_list
    space = int(n / 2)
    while space > 0:
        for i in range(space, n):
            temp = my_list[i]
            j = i
            while j >= space and my_list[j - space] > temp:
                my_list[j] = my_list[j - space]
                j -= space
            my_list[j] = temp
        space = int(space / 2)
    return my_list
if __name__ == "__main__":
    my_list = [8, 0, 4, 3, 2, 1]
    print("排序前的数组:", my_list)
    print("排序后的数组:", shell_sort(my_list))

运行之后,效果如下所示:


相关文章
|
21小时前
|
算法 数据可视化 Python
Python用MCMC马尔科夫链蒙特卡洛、拒绝抽样和Metropolis-Hastings采样算法
Python用MCMC马尔科夫链蒙特卡洛、拒绝抽样和Metropolis-Hastings采样算法
12 6
|
1天前
|
机器学习/深度学习 算法 搜索推荐
Python用机器学习算法进行因果推断与增量、增益模型Uplift Modeling智能营销模型
Python用机器学习算法进行因果推断与增量、增益模型Uplift Modeling智能营销模型
28 12
|
7天前
|
算法 数据可视化 Python
Python贝叶斯推断Metropolis-Hastings(M-H)MCMC采样算法的实现
Python贝叶斯推断Metropolis-Hastings(M-H)MCMC采样算法的实现
11 0
|
7天前
|
数据可视化 算法 数据挖掘
PYTHON实现谱聚类算法和改变聚类簇数结果可视化比较
PYTHON实现谱聚类算法和改变聚类簇数结果可视化比较
|
8天前
|
算法 数据可视化 Python
Python中LARS和Lasso回归之最小角算法Lars分析波士顿住房数据实例
Python中LARS和Lasso回归之最小角算法Lars分析波士顿住房数据实例
13 0
|
8天前
|
机器学习/深度学习 算法 Python
使用Python实现集成学习算法:Bagging与Boosting
使用Python实现集成学习算法:Bagging与Boosting
18 0
|
9天前
|
Python
python学习-函数模块,数据结构,字符串和列表(下)
python学习-函数模块,数据结构,字符串和列表
49 0
|
9天前
|
缓存 算法 Python
python算法对音频信号处理Sonification :Gauss-Seidel迭代算法
python算法对音频信号处理Sonification :Gauss-Seidel迭代算法
|
12天前
|
算法 数据可视化 数据挖掘
使用Python实现DBSCAN聚类算法
使用Python实现DBSCAN聚类算法
151 2
|
13天前
|
存储 算法 安全
Python加密算法有哪些?有什么作用?
这些加密算法的作用在于保护敏感数据的隐私和完整性。它们可以用于数据传输、存储、身份验证和数字签名等领域。通过加密,可以确保数据在传输和存储过程中不被未经授权的人访问或篡改。同时,数字签名可以用于验证数据的来源和完整性,防止数据被篡改或冒充。不同的加密算法在不同的应用场景中起到不同的作用,选择合适的算法取决于安全需求和性能要求。 买CN2云服务器,免备案服务器,高防服务器,就选蓝易云。百度搜索:蓝易云
8 0