希尔排序

来源:互联网 发布:r语言高性能编程 pdf 编辑:程序博客网 时间:2024/06/14 12:55
什么是希尔排序 ?

希尔排序(ShellSort)是插入排序的一种。也称缩小增量排序,是插入排序算法的一种更高效的改进版本。希尔排序是非稳定排序算法。该方法因DLShell1959年提出而得名。希尔排序是把记录按下标的一定增量分组,对每组使用直接插入排序算法排序;随着增量逐渐减少,每组包含的关键词越来越多,当增量减至1时,整个文件恰被分成一组,算法便终止。


(比较的时候以总长的一半作为步长从左往右进行跳跃比较,每轮结束步长减1,直到步长为0,结束)
将li按照升序进行排序
li = [9,8,7,6,5,4,3,2,1,0]
n = len(li)
def shell(li):
stap = n//2
while stap>0:
for i in range(0,n-stap):
if li[i] > li[i+stap]:
li[i],li[i+stap] = li[i+stap],li[i]
stap -= 1
return li
if __name__ = "__main__":
s = shell(li)
print(s)

时间复杂度

根据步长序列的不同而不同,O(n)<=时间复杂度<=O(n2)

稳定性:不稳定



原创粉丝点击
热门问题 老师的惩罚 人脸识别 我在镇武司摸鱼那些年 重生之率土为王 我在大康的咸鱼生活 盘龙之生命进化 天生仙种 凡人之先天五行 春回大明朝 姑娘不必设防,我是瞎子 vivo手机没有otg功能怎么办 头戴耳机压头发怎么办 小米4c很卡怎么办 小米4c玩王者怎么办 小米4s屏幕乱跳怎么办 小米4s手机后壳碎了怎么办 小米5spius开不了机怎么办 小米5s无限重启怎么办 小米5s外屏坏了怎么办 小米5s内屏碎了怎么办 小米4充电没反应怎么办 小米5手机变卡了怎么办 小米5变卡了怎么办 小米手机充电无反应怎么办 小米6相机卡顿怎么办 华为手机玩游戏发热怎么办 华为手机变慢了怎么办 华为p10手机变慢怎么办 华为手机账户密码忘记了怎么办 QQ浏览器无法加载插件怎么办 电脑开了机黑屏怎么办 扫描仪打不开运单扫描怎么办 打印机不支持64位系统怎么办 xp系统dnf闪退怎么办 w10电脑所有程序都打不开怎么办 安卓手机太卡怎么办 系统装到f盘了怎么办 虚拟机占c盘内存怎么办 外机连无线虚拟机显示受限怎么办 使用msdn下载解压后怎么办 路由80端口被占用怎么办 c盘拒绝粘贴文件怎么办 oracle数据库密码忘了怎么办 电脑开机时不显示用户名怎么办? xp系统忘记开机密码怎么办 电脑开机密码忘了怎么办 c盘满了怎么办win10 win10电脑开机密码忘了怎么办 win10的开机密码忘了怎么办 u盘中了exe病毒怎么办 眼睛长个麦粒豆怎么办