Python入门篇-数据结构堆排序Heap Sort

                                      作者:尹正杰

版权声明:原创作品,谢绝转载!否则将追究法律责任。

一.堆Heap

  堆是一个完全二叉树
  每个非叶子结点都要大于或者等于其左右孩子结点的值称为大顶堆
  每个非叶子结点都要小于或者等于其左右孩子结点的值称为小顶堆
  根结点一定是大顶堆中的最大值,一定是小顶堆中的最小值

二.大顶堆

  完全二叉树的每个非叶子结点都要大于或者等于其左右孩子结点的值称为大顶堆
  根结点一定是大顶堆中的最大值

三.小顶堆

  完全二叉树的每个非叶子结点都要小于或者等于其左右孩子结点的值称为小顶堆
  根结点一定是小顶堆中的最小值

四.构建完全二叉树

  待排序数字为30,,,,,,,,90.
  构建一个完全二叉树存放数据,并根据性质5对元素编号,放入顺序的数据结构中.
  构造一个列表为[,,,,,,,,,].

五.构建大顶堆 

1>.核心算法

  度数为2的结点A,如果它的左右孩子结点的最大值比它大的,将这个最大值和该结点交换.
  度数为1的结点A,如果它的左孩子的值大于它,则交换.
  如果结点A被交换到新的位置,还需要和其孩子结点重复上面的过程.

2>.起点结点的选择

  从完全二叉树的最后一个结点的双亲结点开始,即最后一层的最右边叶子结点的父结点开始.
  结点数为n,则起始结点的编号为n//2(性质5).

3>.下一个结点的选择

  从起始结点开始向左找其同层结点,到头后再从上一层的最右边结点开始继续向左逐个查找,直至根结点.

4>.大顶堆的目标

  确保每个结点的都比左右结点的值大.

5>.排序

  将大顶堆根结点这个最大值和最后一个叶子结点交换,那么最后一个叶子结点就是最大值,将这个叶子结点排除在待排序结点之外.
  从根结点开始(新的根结点),重新调整为大顶堆后,重复上一步.
  堆顶和最后一个结点交换,并排除最后一个结点.

 6>.代码实现

 #!/usr/bin/env python
#_*_coding:utf-8_*_
#@author :yinzhengjie
#blog:http://www.cnblogs.com/yinzhengjie/tag/python%E8%87%AA%E5%8A%A8%E5%8C%96%E8%BF%90%E7%BB%B4%E4%B9%8B%E8%B7%AF/
#EMAIL:y1053419035@qq.com import math def print_tree(array):
index = 1
depth = math.ceil(math.log2(len(array))) #因为补0了,不然应该是math.ceil(math.log2(len(array) + 1)
sep = " "
for i in range(depth):
offset = 2 ** i
print(sep * (2 **(depth - i -1)-1),end="")
line = array[index:index + offset]
for j,x in enumerate(line):
print("{:>{}}".format(x,len(sep)),end="")
interval = 0 if i == 0 else 2 ** (depth - i) -1
if j < len(line) - 1:
print(sep * interval,end="")
index += offset
print() #为了和编码对应,增加一个无用的0在首位
origin = [0,30,20,80,40,50,10,60,70,90]
total = len(origin) - 1 #初始化排序元素个数,即n
print(origin) print_tree(origin)
print_tree("=" * 50) def heap_adjust(n,i,array:list):
"""
调整当前结点(核心算法)
调整的节点的起点在n//2,保证所有的调整的结点都有孩子结点
:param n: 待比较数个数
:param i: 当前结点的下标
:param array:待排序的数据
:return:
"""
while 2 * i <= n:
#孩子结点判断2i位左孩子,2i+1为右孩子
lchile_index = 2 * i
max_child_index = lchile_index #n = 2i
if n > lchile_index and array[lchile_index +1] > array[lchile_index]: #n > 2i说明还有右孩子
max_child_index = lchile_index + 1 #n = 2i +1 #和子树的根结点比较
if array[max_child_index] > array[i]:
array[i],array[max_child_index] = array[max_child_index],array[i]
i = max_child_index #被比较后,需要判断是否需要调整
else:
break #构建大顶推,大根堆
def max_heap(total,array:list):
for i in range(total//2,0,-1):
heap_adjust(total,i,array)
return array print_tree(max_heap(total,origin))
print_tree("=" * 50) #排序
def sort(total,array:list):
while total > 1:
array[1],array[total] = array[total],array[1] #堆顶和最后一个结点交换
total -= 1
if total == 2 and array[total] >= array[total -1]:
break
heap_adjust(total,1,array)
return array print_tree(sort(total,origin))
print_tree(origin)

六.总结

是利用堆性质的一种选择排序,在堆顶选出最大值或者最小值
  时间复杂度.
  堆排序的时间复杂度为O(nlogn).
  由于堆排序对原始记录的排序状态并不敏感,因此它无论是最好、最坏和平均时间复杂度均为O(nlogn).

1>.空间复杂度

  只是使用了一个交换用的空间,空间复杂度就是O().

2>.稳定性

  不稳定的排序算法.

Python入门篇-数据结构堆排序Heap Sort的更多相关文章

  1. Python入门篇-数据结构树(tree)的遍历

    Python入门篇-数据结构树(tree)的遍历 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.遍历 迭代所有元素一遍. 二.树的遍历 对树中所有元素不重复地访问一遍,也称作扫 ...

  2. Python入门篇-数据结构树(tree)篇

    Python入门篇-数据结构树(tree)篇 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.树概述 1>.树的概念 非线性结构,每个元素可以有多个前躯和后继 树是n(n& ...

  3. 数据结构 - 堆排序(heap sort) 具体解释 及 代码(C++)

    堆排序(heap sort) 具体解释 及 代码(C++) 本文地址: http://blog.csdn.net/caroline_wendy 堆排序包括两个步骤: 第一步: 是建立大顶堆(从大到小排 ...

  4. Python入门篇-封装与解构和高级数据类型集合(set)和字典(dict)

    Python入门篇-封装与解构和高级数据类型集合(set)和字典(dict) 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.封装和结构 #!/usr/bin/env pytho ...

  5. Python入门篇-基础数据类型之整型(int),字符串(str),字节(bytes),列表(list)和切片(slice)

    Python入门篇-基础数据类型之整型(int),字符串(str),字节(bytes),列表(list)和切片(slice) 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.Py ...

  6. Python入门篇-面向对象概述

    Python入门篇-面向对象概述 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.语言的分类 面向机器 抽象成机器指令,机器容易理解 代表:汇编语言 面向过程 做一件事情,排出个 ...

  7. Python入门篇-高阶函数

    Python入门篇-高阶函数 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.高级函数  1>.First Class Object 函数在Python中是一等公民 函数也 ...

  8. Python入门篇-基础语法

    Python入门篇-基础语法 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.编程基础 1>.程序 一组能让计算机识别和执行的指令. 程序 >.算法+ 数据结构= 程 ...

  9. Python入门篇-StringIO和BytesIO

    Python入门篇-StringIO和BytesIO 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.StringIO(用于文本处理) 1>.使用案例 #!/usr/bin ...

随机推荐

  1. EasyDSS高性能RTMP、HLS(m3u8)、HTTP-FLV、RTSP流媒体服务器解决方案之Windows服务安装

    背景说明 EasyDSS流媒体解决方案是由安徽旭帆信息科技有限公司自主研发的一套集流媒体点播.转码.管理.直播.录像.检索.时移回看于一体的一套完整的商用流媒体解决方案.EasyDSS软件以压缩包的形 ...

  2. nginx使用与配置入门指南

    这是一篇关于nginx使用与配置的入门指南,但不包括nginx的编译与安装.我假定你知晓如何安装nginx.对大多数Linux系统来说,nginx都已经存在于它们的软件包里,直接使用系统提供的软件管理 ...

  3. linux服务器之间文件传输

    有时候我们会遇到,把一个服务器上的文件夹,传到另一个服务器 我们需要先把文件夹打包成 tar.gz,这种格式在任何linux版本上都能压缩/解压 #解压命令 tar -zxvf xxx.tar.gz ...

  4. c# – Asp.Net Core MVC中Request.IsAjaxRequest()在哪里?

    要了解有关新的令人兴奋的Asp.Net-5框架的更多信息,我正在使用最新发布的Visual Studio 2015 CTP-6来构建一个Web应用程序. 大多数事情看起来真的很有希望,但我似乎找不到R ...

  5. mongodb4.2.2 centos 单机安装

    下载 rpm包 wget https://repo.mongodb.org/yum/redhat/7/mongodb-org/4.2/x86_64/RPMS/mongodb-org-server-4. ...

  6. RobotFrameWork中使用自定义关键字

    今天尝试在RF中使用一下自己写的关键字. 1.首先写一个py文件,如下,简单打印个message 2.在RF中点击library,把写的py文件加进来 3.使用函数mylog,有一个参数,也可以F5看 ...

  7. C++ 每日一题 参数分析 (vector)

    首先给出原题地址: https://www.nowcoder.com/practice/668603dc307e4ef4bb07bcd0615ea677?tpId 以下是代码解析: #include& ...

  8. PHP下载远程图片到本地的几种方法总结(tp5.1)

    1.CURL 2.使用file_get_contents 3.使用fopen 参考链接:https://www.jb51.net/article/110615.htm

  9. laravel 自定义验证 Validator::extend

    laravel 自定义验证 $messages = [ 'name.integer' => '名字不能为整型', 'name.max' => '长度不能超过5', ]; public st ...

  10. asp.net core 之中间件

    Http请求资源的过程可以看成一个管道:“Pipe”,并不是所有的请求都是合法的.安全的,其于功能.性能或安全方面的考虑,通常需要在这管道中装配一些处理程序来筛选和加工这些请求.这些处理程序就是中间件 ...