用调整法和插入法建堆的Python实现,不同建堆方式对堆排序性能的影响

本文主要是介绍用调整法和插入法建堆的Python实现,不同建堆方式对堆排序性能的影响,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

       建堆的方式大体有两种,一种是插入法,一种是调整法,其中以调整法比较常见。由于他们的建堆的思路不同,所以两种方法建堆结果可能不一样。

       插入法建堆是将数组1中的元素逐个插入到数组2中建立一个堆。以小根堆为例,每插入一个关键字就与其父节点的关键字比较大小,如果父节点的关键字较大则交换,然后依次自底地向上调整使之符合小根堆的特性。在某棵已插入根节点的子树中,当插入左节点时,左节点与根节点交换,插入右节点时,右节点与根节点交换,那么这种情况下这颗子树三个节点的位置都发生改变了。因此插入法建堆结果与插入的顺序和值大小有关。

       调整法建堆是自底向上依次调整,一棵子树中最小的节点值与根节点交换,最大的那个节点位置在本次调整中不作改变。即这种方法建堆有一个节点位置不变。

        下面是插入法和调整法建堆的Python代码:

import random
import datetime#make random file
def creatIntRandom():count = 100output = open('data_100.txt','w+')while count:output.write(str(random.randint(0,1000001)) + '\n')count = count - 1output.closedef txtToList():int_list = []in_file = open('data.txt')in_text = in_file.readlines()   for line in in_text:num = int(line[0 : len(line) - 1])int_list.append(num) in_file.close()return int_list#----------------------------------
def minHeapify(list, heapsize, index):left = 2*index + 1right = 2*index + 2mini = indexif left < heapsize:if list[mini] > list[left]:mini = leftif right < heapsize and list[mini] > list[right]:mini = rightif mini != index:list[mini], list[index] = list[index], list[mini]minHeapify(list, heapsize, mini)def buildMinHeap_1(list):heapSize = len(list)if heapSize < 2:returnfor i in range(heapSize/2 - 1, -1, -1):minHeapify(list, heapSize, i)def heapSort_1(list):buildMinHeap_1(list)for i in range(len(list) - 1, -1, -1):list[0], list[i] = list[i], list[0]minHeapify(list, i, 0)return list    #-------------------------------------------
def buildMinHeap_2(list_1):heapsize = 0list_2 = [0]*(len(list_1) + 1)for i in range(len(list_1)):heapsize = i + 1list_2[heapsize] = list_1[i]while heapsize > 2 and list_2[heapsize/2] > list_2[heapsize]:list_2[heapsize], list_2[heapsize/2] = list_2[heapsize/2], list_2[heapsize]heapsize/=2return list_2[1:len(list_2)]def heapSort_2(list):list_2 = buildMinHeap_2(list)for i in range(len(list)-1, -1, -1):list_2[0], list_2[i] = list_2[i], list_2[0]minHeapify(list_2, i, 0)return list_2#------------------------------------------
def verify(list):for i in range(len(list) - 1):if list[i] >= list[i+1]:passelse:return Falsereturn Truedef test():list_in = txtToList()time_start_1 = datetime.datetime.now()list_out_1 = heapSort_1(list_in)time_end_1 = datetime.datetime.now()#print list_out_1print verify(list_out_1)print (time_end_1 - time_start_1)time_start_2 = datetime.datetime.now()list_out_2 = heapSort_2(list_in)time_end_2 = datetime.datetime.now()#print list_out_2print verify(list_out_1)print (time_end_2 - time_start_2)#creatIntRandom()
test()


        下图是对100W个随机产生的整数进行堆排序的运行结果:

    

 


        调整法的时间复杂度:建堆耗时0.5NlogN,排序耗时NlogN,累计1.5NlogN。
        插入法的时间复杂度:建堆耗时NlogN,排序耗时NlogN,累计2NlogN。
        从以上的比较中可以看出,虽然两种方法的时间复杂度在数量级是一样的,但是由于建堆所耗费的时间不同,总体时间有所不同,从上图执行的结果可以看出来:上面是调整法建堆并排序所耗时间,下面是插入法建堆并排序所耗时间。基本符合上述分析。




这篇关于用调整法和插入法建堆的Python实现,不同建堆方式对堆排序性能的影响的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/971155

相关文章

MySQL深分页进行性能优化的常见方法

《MySQL深分页进行性能优化的常见方法》在Web应用中,分页查询是数据库操作中的常见需求,然而,在面对大型数据集时,深分页(deeppagination)却成为了性能优化的一个挑战,在本文中,我们将... 目录引言:深分页,真的只是“翻页慢”那么简单吗?一、背景介绍二、深分页的性能问题三、业务场景分析四、

Spring StateMachine实现状态机使用示例详解

《SpringStateMachine实现状态机使用示例详解》本文介绍SpringStateMachine实现状态机的步骤,包括依赖导入、枚举定义、状态转移规则配置、上下文管理及服务调用示例,重点解... 目录什么是状态机使用示例什么是状态机状态机是计算机科学中的​​核心建模工具​​,用于描述对象在其生命

Spring Boot 结合 WxJava 实现文章上传微信公众号草稿箱与群发

《SpringBoot结合WxJava实现文章上传微信公众号草稿箱与群发》本文将详细介绍如何使用SpringBoot框架结合WxJava开发工具包,实现文章上传到微信公众号草稿箱以及群发功能,... 目录一、项目环境准备1.1 开发环境1.2 微信公众号准备二、Spring Boot 项目搭建2.1 创建

IntelliJ IDEA2025创建SpringBoot项目的实现步骤

《IntelliJIDEA2025创建SpringBoot项目的实现步骤》本文主要介绍了IntelliJIDEA2025创建SpringBoot项目的实现步骤,文中通过示例代码介绍的非常详细,对大家... 目录一、创建 Spring Boot 项目1. 新建项目2. 基础配置3. 选择依赖4. 生成项目5.

Linux线程之线程的创建、属性、回收、退出、取消方式

《Linux线程之线程的创建、属性、回收、退出、取消方式》文章总结了线程管理核心知识:线程号唯一、创建方式、属性设置(如分离状态与栈大小)、回收机制(join/detach)、退出方法(返回/pthr... 目录1. 线程号2. 线程的创建3. 线程属性4. 线程的回收5. 线程的退出6. 线程的取消7.

使用Python删除Excel中的行列和单元格示例详解

《使用Python删除Excel中的行列和单元格示例详解》在处理Excel数据时,删除不需要的行、列或单元格是一项常见且必要的操作,本文将使用Python脚本实现对Excel表格的高效自动化处理,感兴... 目录开发环境准备使用 python 删除 Excphpel 表格中的行删除特定行删除空白行删除含指定

MySQL 多列 IN 查询之语法、性能与实战技巧(最新整理)

《MySQL多列IN查询之语法、性能与实战技巧(最新整理)》本文详解MySQL多列IN查询,对比传统OR写法,强调其简洁高效,适合批量匹配复合键,通过联合索引、分批次优化提升性能,兼容多种数据库... 目录一、基础语法:多列 IN 的两种写法1. 直接值列表2. 子查询二、对比传统 OR 的写法三、性能分析

golang程序打包成脚本部署到Linux系统方式

《golang程序打包成脚本部署到Linux系统方式》Golang程序通过本地编译(设置GOOS为linux生成无后缀二进制文件),上传至Linux服务器后赋权执行,使用nohup命令实现后台运行,完... 目录本地编译golang程序上传Golang二进制文件到linux服务器总结本地编译Golang程序

Linux下删除乱码文件和目录的实现方式

《Linux下删除乱码文件和目录的实现方式》:本文主要介绍Linux下删除乱码文件和目录的实现方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录linux下删除乱码文件和目录方法1方法2总结Linux下删除乱码文件和目录方法1使用ls -i命令找到文件或目录

SpringBoot+EasyExcel实现自定义复杂样式导入导出

《SpringBoot+EasyExcel实现自定义复杂样式导入导出》这篇文章主要为大家详细介绍了SpringBoot如何结果EasyExcel实现自定义复杂样式导入导出功能,文中的示例代码讲解详细,... 目录安装处理自定义导出复杂场景1、列不固定,动态列2、动态下拉3、自定义锁定行/列,添加密码4、合并