Python排序搜索基本算法之希尔排序实例分析
作者:littlethunder 时间:2023-03-27 14:06:07
本文实例讲述了Python排序搜索基本算法之希尔排序。分享给大家供大家参考,具体如下:
希尔排序是插入排序的扩展,通过允许非相邻的元素进行交换来提高执行效率。希尔排序最关键的是选择步长,本程序选用Knuth在1969年提出的步长序列:1 4 13 40 121 364 1093 3280 。。。后一个元素是前一个元素*3+1,非常方便选取,而且效率还不错。代码如下:
#-*- coding: UTF-8 -*-
def shellSort(seq):
length=len(seq)
inc=0
while inc<=length/3:
inc=inc*3+1
print(inc)
while inc>=1:
for i in range(inc,length):
tmp=seq[i]
for j in range(i,0,-inc):
if tmp<seq[j-inc]:
seq[j]=seq[j-inc]
else:
j+=inc
break
seq[j-inc]=tmp
inc//=3
if __name__=='__main__':
print("脚本之家测试结果:")
seq=[8,6,4,9,7,3,2,-4,0,-100,99]
shellSort(seq)
print(seq)
运行结果:
PS:这里再为大家推荐一款关于排序的演示工具供大家参考:
在线动画演示插入/选择/冒泡/归并/希尔/快速排序算法过程工具:
http://tools.jb51.net/aideddesign/paixu_ys
希望本文所述对大家Python程序设计有所帮助。
来源:http://blog.csdn.net/littlethunder/article/details/9472055
标签:Python,算法,希尔排序
0
投稿
猜你喜欢
详解python tkinter模块安装过程
2021-05-18 04:19:38
mysql第一次安装成功后初始化密码操作步骤
2024-01-19 22:20:45
用代码帮你了解Python基础(2)
2022-01-04 23:42:40
Oracle11.2 命令行手工最简创建数据库的过程
2009-09-14 12:07:00
Python编程使用matplotlib挑钻石seaborn画图入门教程
2021-04-12 18:28:17
Python机器学习入门(五)之Python算法审查
2021-10-15 09:27:48
M1芯片Mac上Anaconda的暂时替代(miniforge)
2022-12-12 00:32:43
python asyncio 协程库的使用
2022-09-13 13:28:16
Eclipse 格式化代码时不换行与自动换行的实现方法
2023-04-05 03:52:55
Django实现支付宝付款和微信支付的示例代码
2021-01-31 10:16:29
三分钟掌握PHP操作数据库
2023-06-01 01:15:43
Elasticsearches打分机制讲解
2023-05-31 10:41:03
SQL Server 2005数据转换服务设计问题集锦
2008-12-26 17:29:00
Django中自定义查询对象的具体使用
2021-05-26 03:11:18
1亿条数据在PHP中实现Mysql数据库分表100张
2011-06-02 09:31:00
教你怎么用python selenium实现自动化测试
2022-01-17 04:42:53
举例讲解Python中的算数运算符的用法
2022-03-30 22:14:49
python使用PIL实现多张图片垂直合并
2023-10-28 12:19:45
pandas数据聚合与分组运算的实现
2021-09-18 18:29:12
python排序算法之选择排序
2023-03-15 11:56:56