基于Python3的数据结构与算法 - 09 希尔排序

一、引入

希尔排序是一种分组插入排序的算法。

二、排序思路

  1. 首先取一个整数d1 = n/2,将元素分为d1个组,每组相邻量取元素距离为d1,在各组内直接进行插入排序;
  2. 取第二个整数d2 = d1/2, 重复上述分组排序过程,直到d1 = 1,即所有元素在同意最内进行直接插入排序。
  3. 希尔排序每趟并不使某些元素有序,而是使整体数据越来越接近有序;最后一趟排序使得所有数据有序。

如下图所示:n = 9 ; d1 = n // 2 = 4 ; 第一次将其分为四组;每组进行一次插入排序,排序完成后返回。

第二次将其分为 d1 = d // 2  = 2组后再重新进行插入排序:

直到最后d = 1时,再对整体进行一次插入排序

 

三、代码思路

1. 按照间隔为gap的插入

相当于每次间隔gap进行一次插入排序,对比之前写的插入排序,相当于将其中的1变为gap。

示例代码:

def insert_sort_gap(li, gap):for i in range(gap, len(li)):  # i 表示摸到牌的下表; 总共n张牌,起始手里有一张牌tmp = li[i]  # 将摸到的牌存起来j = i - gap  # j指的是手里牌的下标,初始手里有一张牌while j >= 0 and li[j] > tmp:   # 将手里的牌和摸到的牌作比较;摸到的牌小于手里的牌andli[j + gap] = li[j]  # 往右挪位置j -= gap  # 缩小j后继续比较li[j + gap] = tmp   # j往前移后继续比较;如果此时摸到的牌大于li[j],则将摸到的牌放到j+1的位置print(li)

 接下来我们再写希尔排序的代码:

def shell_sort(li):d = len(li) // 2while d >= 1 :insert_sort_gap(li, d)d //= 2

因此总的演示代码如下所示:

def insert_sort_gap(li, gap):for i in range(gap, len(li)):  # i 表示摸到牌的下表; 总共n张牌,起始手里有一张牌tmp = li[i]  # 将摸到的牌存起来j = i - gap  # j指的是手里牌的下标,初始手里有一张牌while j >= 0 and li[j] > tmp:   # 将手里的牌和摸到的牌作比较;摸到的牌小于手里的牌andli[j + gap] = li[j]  # 往右挪位置j -= gap  # 缩小j后继续比较li[j + gap] = tmp   # j往前移后继续比较;如果此时摸到的牌大于li[j],则将摸到的牌放到j+1的位置def shell_sort(li):d = len(li) // 2while d >= 1 :insert_sort_gap(li, d)d //= 2li = [1,4,7,2,5,8,3,6,9]
print(li)
shell_sort(li)
print(li)

输出结果如下:

四、时间复杂度

希尔排序的时间复杂度比较复杂,并且和选取的gap序列有关。 

 

如上图所示,选取不同的gap序列时希尔排序具有不同的时间复杂度,且存在一些复杂的gap序列使得无法计算其复杂度,但总的来说,希尔排序的时间复杂度比基础排序快,比进阶排序慢。 

 

 

 

 

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/504122.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

LeetCode 刷题 [C++] 第215题.数组中的第K个最大元素

题目描述 给定整数数组 nums 和整数 k,请返回数组中第 k 个最大的元素。 请注意,你需要找的是数组排序后的第 k 个最大的元素,而不是第 k 个不同的元素。 你必须设计并实现时间复杂度为 O(n) 的算法解决此问题。 题目分析 根据题意分析&…

华为设备总部与分部配置

1.要求: (1)总部实现高可靠性设计,接入层断掉一根线或汇聚、核心设备故障都不能影响数据正常转发 (2)分部1人数较少,采用单臂路由互通 (3)总部、分部1、2之间都能访问互联…

Python 自动化给女友发邮件:含新闻、天气、每日一句、图片 最全攻略系列02 如何添加emoji

Python 自动化给女友发邮件:含新闻、天气、每日一句、图片 最全攻略系列 是否想在女友面前展示程序员炫酷的一面? 是否想给她每日问候但是害怕忘记固定时间发送信息? 是否也羡慕别人可以优雅使用Python定时发送邮件? 欢迎来到Python自动化发邮件最全攻略系列,本系列将…

React富文本编辑器开发(二)

我们接着上一节的示例内容,现在有如下需求,我们希望当我们按下某个按键时编辑器有所反应。这就需要我们对编辑器添加事件功能onKeyDown, 我们给 Editor添加事件: SDocor.jsx import { useState } from react; import { createEditor } from…

你心中的韩剧TOP1是哪一部

关注公众号:萌番bilfun,发送影片名称,即可获取资源链接 【2024最新韩剧来袭,准备好迎接心灵的震撼了吗?】 韩剧迷们,你们期待已久的2024最新韩剧终于来了!准备好迎接心灵的震撼了吗&#xff1f…

mTLS: TLS/CA/证书 简介

TLS 传输层安全性协议(英语:Transport Layer Security,缩写作TLS),及其前身安全套接层(Secure Sockets Layer,缩写作SSL)是一种安全协议,目的是为互联网通信提供安全及数…

【软考】UML中的图之通信图

目录 1. 说明2. 图示3. 特性4. 例题4.1 例题1 1. 说明 1.通信图强调收发消息的对象的结构组织2.早期版本叫做协作图3.通信图强调参加交互的对象和组织4.首先将参加交互的对象作为图的顶点,然后把连接这些对象的链表示为图的弧,最后用对象发送和接收的消…

Tomcat 部署和优化 (一)---------安装Oracle jdk 、tomcat

自 2017 年 11 月编程语言排行榜 Java 占比 13%,高居榜首,Tomcat 也一度成为 Java开发人员的首选。其开源、占用系统资源少、跨平台等特性被深受喜爱。本章主要学习如何部署 Tomcat 服务,根据生产环境实现多个虚拟主机的配置,最后…

24款奔驰C260L升级原厂360全景影像 高清环绕的视野

360全景影像影像系统提升行车时的便利,不管是新手或是老司机都将是一个不错的配置,无论是在倒车,挪车以及拐弯转角的时候都能及时关注车辆所处的环境状况,避免盲区事故发生,提升行车出入安全性。星骏汇小许Xjh15863 3…

人工智能基础——模型部分:模型介绍、模型训练和模型微调 !!

文章目录 前言 一、什么是模型 二、什么是模型训练 三、什么是模型微调 前言 本文将从什么是模型?什么是模型训练?什么是模型微调?三个问题,来展开介绍人工智能基础的模型部分。 模型族谱 一、什么是模型 模型是一个函数&#x…

SpringBoot整合JdbcTemplate

✅作者简介:大家好,我是Leo,热爱Java后端开发者,一个想要与大家共同进步的男人😉😉 🍎个人主页:Leo的博客 💞当前专栏: 循序渐进学SpringBoot ✨特色专栏: MySQL学习 🥭本文内容:SpringBoot整合JdbcTemplate 📚个人知识库: Leo知识库,欢迎大家访问 目录 …

Linux中systemv共享内存

目录 1.原理 2.接口 1.shmget(share_memory_get获得共享内存) 2.ftok 3.shmat(share_memory_attaintion挂接到物理内存上) 4.key和shmid的区别 5.ipc 指令 6.shmdt函数(share_memory_detach取消挂接) 7.shmctl函数(share_memory_cont…