当前位置: 首页 > 编程日记 > 正文

用python写希尔排序_python希尔排序介绍(实例)

希尔排序介绍

希尔排序(Shell Sort)是插入排序的一种。也称缩小增量排序,是直接插入排序算法的一种更高效的改进版本,该方法的基本思想是:先将整个待排元素序列分割成若干个子序列(由相隔某个“增量”的元素组成的)分别进行直接插入排序,然后依次缩减增量再进行排序,待整个序列中的元素基本有序(增量足够小)时,再对全体元素进行一次直接插入排序。因为直接插入排序在元素基本有序的情况下(接近最好情况),效率是很高的,因此希尔排序在时间效率比直接插入排序有较大提高。

ed4ecd39e3d63403885c062e96e57c99.png

首先要明确一下增量的取法: 第一次增量的取法为: d=count/2;

第二次增量的取法为: d=(count/2)/2;

最后一直到: d=1; 看上图观测的现象为: d=3时:将40跟50比,因50大,不交换。

将20跟30比,因30大,不交换。

将80跟60比,因60小,交换。

d=2时:将40跟60比,不交换,拿60跟30比交换,此时交换后的30又比前面的40小,又要将40和30交换,如上图。

将20跟50比,不交换,继续将50跟80比,不交换。

d=1时:这时就是前面讲的插入排序了,不过此时的序列已经差不多有序了,所以给插入排序带来了很大的性能提高。

代码实例:

import time,random

#source = [8, 6, 4, 9, 7, 3, 2, -4, 0, -100, 99]

#source = [92, 77, 8,67, 6, 84, 55, 85, 43, 67]

source = [ random.randrange(10000+i) for i in range(10000)]

#print(source)

step = int(len(source)/2) #分组步长

t_start = time.time()

while step >0:

print("---step ---", step)

#对分组数据进行插入排序

for index in range(0,len(source)):

if index + step < len(source):

current_val = source[index] #先记下来每次大循环走到的第几个元素的值

if current_val > source[index+step]: #switch

source[index], source[index+step] = source[index+step], source[index]

step = int(step/2)

else: #把基本排序好的数据再进行一次插入排序就好了

for index in range(1, len(source)):

current_val = source[index] # 先记下来每次大循环走到的第几个元素的值

position = index

while position > 0 and source[

position - 1] > current_val: # 当前元素的左边的紧靠的元素比它大,要把左边的元素一个一个的往右移一位,给当前这个值插入到左边挪一个位置出来

source[position] = source[position - 1] # 把左边的一个元素往右移一位

position -= 1 # 只一次左移只能把当前元素一个位置 ,还得继续左移只到此元素放到排序好的列表的适当位置 为止

source[position] = current_val # 已经找到了左边排序好的列表里不小于current_val的元素的位置,把current_val放在这里

print(source)

t_end = time.time() - t_start

print("cost:",t_end)

希望与广大网友互动??

点此进行留言吧!

相关文章:

【No.5 类型转换导致的错误】

【注意】 程序语言只是我们与计算机交流并让计算机实现我们创造性思想的工具&#xff0c;可以并鼓励深入掌握一门语言&#xff0c;但千万别沉迷于钻某种语言的牛角尖&#xff0c;一定要把握好二者间的度本帖属不定时连载贴&#xff0c;以试卷的形式提出一个比较基础的问题供大家…

小学AI教材终于来了,下一步是AI胎教吗?

小学生终于也要学 AI 了&#xff01;据澎湃新闻报道&#xff0c;全国首套涵盖了从小学到高中的人工智能教材近日在上海正式发布&#xff0c;这套“AI上未来智造者”丛书计划出版 10 册&#xff0c;目前已出版 6 册&#xff0c;分别为《AI上神奇动物》、《AI上智慧生活》《AI在变…

快过年了,博客园里的文章也变少了

快过年了&#xff0c;博客园里的文章也变少了&#xff0c;大家都开始休息了吗&#xff1f;转载于:https://www.cnblogs.com/RobotTech/archive/2008/02/03/1063461.html

字符串多模式精确匹配(脏字/敏感词汇/关键字过滤算法)——TTMP算法 之实战F模式...

前面那么多篇文章都太抽象&#xff0c;这次来一个稍微实际一点的。F模式是我实际上选用的模式&#xff0c;对该模式我做了不少实际的测试&#xff0c;因此代码也算是比较稳定的。不过由于实际上为了得到该算法的效率&#xff0c;算法本身做了一些优化&#xff0c;对于初学者&am…

深入java_深入Java Final

JAVA关键字final用于修饰数据、方法或类&#xff0c;通常意味着“无法改变的”&#xff0c;既数据不能改变&#xff0c;方法不能覆盖&#xff0c;类不能继承。一般采用final有两种原因&#xff1a;设计和效率。而随着JAVA版本的更新&#xff0c;一些效率上的问题可以交由编译器…

盛会再临,2018中国大数据技术大会(BDTC)首曝日程及议题

满目皆干货&#xff0c;俯仰尽拾珠。作为年度技术趋势与行业应用的风向标&#xff0c;连续成功举办十一年的中国大数据技术大会&#xff08;BDTC&#xff09;携主题“大数据新应用”再度强势来袭&#xff0c;稳踏技术时代浪潮&#xff0c;势将引爆今冬技术圈。 数据&#xff0c…

Linux下修改MAC地址总结

偶尔会用到这个知识点&#xff0c;久了不用又会记不住&#xff0c;所以记之&#xff0c;方便以后查询。 Linux下修改MAC地址 方法一&#xff1a; 1.关闭网卡设备 ifconfig eth0 down 2.修改MAC地址 ifconfig eth0 hw ether MAC地址 3.重启网卡 ifconfig eth0 up 或者将以上内容…

hadoop 2 java hdfs_Hadoop2.6.0学习笔记(二)HDFS访问

鲁春利的工作笔记&#xff0c;谁说程序员不能有文艺范&#xff1f;通过hadoop shell与java api访问hdfs工作笔记之Hadoop2.6集群搭建已经将集群环境搭建好了&#xff0c;下面来进行一些HDFS的操作1、HDFS的shell访问HDFS设计主要用来对海量数据进行处理&#xff0c;即HDFS上存储…

知乎如何洞察你的真实喜好?首页信息流技术揭秘

11月8-9日&#xff0c;由中国 IT 社区 CSDN 与硅谷 AI 社区 AICamp 联合出品的 2018 AI 开发者大会&#xff08;AI NEXTCon&#xff09; 在北京举行&#xff0c;就人工智能的最新技术及深度实践&#xff0c;进行了全方位的解读及论证。本文是机器学习技术专题中知乎首页业务总监…

[Web开发] 微软的RSS协议扩展 - FeedSync 介绍 (4)

上一篇文章介绍了在2台电脑上同时修改数据的feedsync 同步过程&#xff0c; 今天再讨论一下当在2台电脑上同时删除同一个数据的情况。 假设最初feed 里面数据是这样的<item><sx:sync id"ep2.100" updates"1" deleted"false" noconflict…

weblogic 修改控制台密码

关掉weblogic所有进程切换到域下面$cd /home/weblogic/Oracle/Middleware/user_projects/domains/jydomain/security$java -classpath /home/weblogic/Oracle/Middleware/wlserver_10.3/server/lib/weblogic.jar weblogic.security.utils.AdminAccount weblogic weblogic123 …

WPF框架的内存泄漏BUG

用户在使用GIX4某模块的过程中&#xff0c;内存只见加不见减。我们怀疑出现了内存泄漏&#xff0c;所以我花了相当一段时间来进行此问题的排查。 我使用Red Gate公司的产品ANTS Memory Profiler 5进行应用程序的内存进行监视。并在过程中修改程序中出现的一些问题。但是最后留下…

java map深拷贝_java 实现Map的深复制

在java中有一个比较有趣的特性&#xff0c;在对对象进行赋值&#xff0c;或者clone时候一般都是我们所说的浅复制&#xff0c;Object A B;也就是说我们获取的并非在堆中重新分配的一块内存&#xff0c;而是一个指向原有数据内存的一个引用。这样的后果就是我们修改了A中的属性…

出门问问工程副总裁黄美玉入选IEEE Fellow,曾担任微软Cortana首席NLP科学家

虽然 IEEE&#xff08;国际电子电气工程协会&#xff09;2019 年的 Fellow 评选结果还未正式出炉&#xff0c;但记者刚刚获悉&#xff0c;IEEE Fellow 又新增一名华人科学家入选——出门问问工程副总裁、Mobvoi AI Lab 的负责人黄美玉博士。黄美玉博士是由于其在语音/语言技术领…

Windows2003服务器不支持FLV视频的解决方法

Windows2003服务器不支持FLV视频的解决方法2007年10月19日 星期五 10:43 A.M.原因&#xff1a;WIN2003加强了IIS6的MIME验证&#xff0c;一切未注册扩展文件格式统统显示404错误。手动在IIS中HTTP头->MIME添加MIME影射关系&#xff0c;MIME类型: video/x-flv 扩展名:.flv&am…

mpi并行 java_【并行计算】用MPI进行分布式内存编程(一)

通过上一篇关于并行计算准备部分的介绍&#xff0c;我们知道MPI(Message-Passing-Interface 消息传递接口)实现并行是进程级别的&#xff0c;通过通信在进程之间进行消息传递。MPI并不是一种新的开发语言&#xff0c;它是一个定义了可以被C、C和Fortran程序调用的函数库。这些函…

JQuery——选择器分类

JQuery选择器1 什么是JQuery选择器快速高效的找到指定节点&#xff0c;支持css语法设置页面2 JQuery选择器分类2.1 基本选择器CSS选择器层级选择器表单域选择器2.2 过滤选择器简单过滤选择器内容过滤选择器属性过滤选择器子元素过滤选择器表单域属性过滤选择器可见性过…

3月6日工作日志-88250

今天&#xff1a; 1. 与zy、vanessa一起使用mingle做了开发计划 2. 使用了XStream重写了XML格式的Dynamic Dictionary Basic Engine TODO&#xff1a; 1. 提高Dynamic Dict引擎的效率 2. 分片转换一部43W词汇的英&#xff0d;中词库(按字母、大小写分片) 转载于:https:/…

专注文本处理,达观数据完成B轮融资,累计融资超2亿元

11月22日&#xff0c;达观数据宣布成功完成1.6亿元B轮融资&#xff0c;由宽带旗下基金晨山资本领投&#xff0c;元禾重元、联想之星、钟鼎资本及老股东等跟投。达观数据总部位于上海张江高科技园区&#xff0c;目前已在北京、成都、深圳、西安等地开设分支机构。2015年获真格基…

Asp.Net Core写个共享磁盘文件Web查看器

查看器功能说明与演示 本查看器主要是为了方便大家查看服务器上的日志&#xff0c;这里没有考虑其他安全性问题&#xff0c;比如特定人员登录才能查看&#xff0c;这个需要您们自己去增加&#xff1b;如果你服务器有对外开放了ip&#xff0c;那么运行这个软件的时候建议考虑配置…

ImageNet时代将终结?何恺明新作:Rethinking ImageNet Pre-training

译者 | 刘畅 林椿眄整理 | Jane出品 | AI科技大本营Google 最新的研究成果 BERT 的热度还没褪去&#xff0c;大家都还在讨论是否 ImageNet 带来的预训练模型之风真的要进入 NLP 领域了。如今&#xff0c;Facebook AI Research 的何恺明、Ross Girshick 及 Piotr Dollar 三位大佬…

java 序列化 缓存_java_缓冲流、转换流、序列化流

一、缓冲流缓冲流的基本原理&#xff0c;是在创建流对象时&#xff0c;会创建一个内置的默认大小的缓冲区数组&#xff0c;通过缓冲区读写&#xff0c;减少系统IO次数&#xff0c;从而提高读写的效率。字节缓冲流构造方法创建字节缓冲输入流&#xff1a;BufferedInputStream bi…

QQ2007去广告教程(本地vip)

只要是vip就可以去掉广告了 关键函数QQHelperDll.dll的IsQQServiceEnable 在入口点修改: mov eax,1 retn 好了这样就成了本地的vip了 因为那个dll的版本太多了不能通用&#xff0c;所以就不提供下载了&#xff08;我的版本7.1.644.1777&#xff09; 同时qq每次升级都有可能替换…

java instanceof 报错_java instanceof方法

基本用法null instanceof Object 为false&#xff1b; null instanceof 任意类 为false&#xff1b;任意实例 instanceof 对应的类或者父类 都为true&#xff1b;基本数据类型 instanceof Object 编译时会报错(如 int a&#xff1b;a instanceof Object 编译不通过)&#xff…

grep的常用命令语法

grep的常用命令语法 1. 双引号引用和单引号引用 在g r e p命令中输入字符串参数时&#xff0c;最好将其用双引号括起来。例如&#xff1a;“m y s t r i n g”。这样做有两个原因&#xff0c;一是以防被误解为 s h e l l命令&#xff0c;二是可以用来查找多个单词组成的字符串&…

千呼万唤始出来!OpenCV 4.0正式发布!

作者 | 周强&#xff08;本文为作者独立观点&#xff0c;转载请联系作者&#xff09;来源 | 我爱计算机视觉OpenCV 4.0 正式版来啦&#xff01;重回英特尔的 OpenCV 终于迎来一次大版本更新&#xff0c;增加了诸多新特性&#xff0c;快来一起看看吧&#xff5e;因为 OpenCV 最开…

ORA-01031: insufficient privileges的解决方法

原文出自:http://www.chinaunix.net/jh/19/132866.html############################################# # # NAME: troubleshoot connect internal.txt # # DESCRIPTION: # connect internal # connect / as sysdba 要口令问题&#xff1a;# refer (METALINK,ORACLEDOC), # me…

java 线程通讯_java多线程(五)线程通讯

1.1. 为什么要线程通信多个线程并发执行时&#xff0c;在默认情况下CPU是随机切换线程的&#xff0c;有时我们希望CPU按我们的规律执行线程&#xff0c;此时就需要线程之间协调通信。1.2. 线程通讯方式线程间通信常用方式如下&#xff1a;l 休眠唤醒方式&#xff1a;Object的w…

合并排序(C语言实现)

递归算法是把一个问题分解成和自身相似的子问题&#xff0c;然后再调用自身把相应的子问题解决掉。这些算法用到了分治思想。其基本模式如下&#xff1a; 分解&#xff1a;把一个问题分解成与原问题相似的子问题 解决&#xff1a;递归的解各个子问题 合并&#xff1a;合并子问题…

工程实践也能拿KDD最佳论文?解读Embeddings at Airbnb

作者 | Mihajlo Grbovic&#xff0c;Airbnb 资深机器学习科学家译者 | Lang Yang&#xff0c;Airbnb 工程经理【导读】本文最早于 2018 年 5 月 13 日发表&#xff0c;主要介绍了机器学习的嵌入技术在 Airbnb 爱彼迎房源搜索排序和实时个性化推荐中的实践。Airbnb 爱彼迎的两位…