堆排序创建 灰太狼 2024-04-06 14:40 67阅读 0赞 #### 堆排序创建 #### * 一、介绍 * * 1、什么是堆 * 2、大项堆(排序前) * 3、小项堆(排序前) * 4、排序思想 * 二、大项堆排序案例 * * 1、流程 * 2、讲解 * 三、总结 -------------------- ## 一、介绍 ## ### 1、什么是堆 ### 堆是一种叫做完全二叉树的数据结构,可以分为大项堆,小项堆,而堆排序就是基于这种结构而产生的一种程序算法。 ### 2、大项堆(排序前) ### 大项堆:每个节点的值都大于或者等于他的左右孩子节点的值 ![在这里插入图片描述][1eb447601e5d4c1ab08af8d4612f50ad.png] ### 3、小项堆(排序前) ### 小项堆:每个结点的值都小于或等于其左孩子和右孩子结点的值 ![在这里插入图片描述][1ffbc197510248578237bcdcce2dbdf7.png] ### 4、排序思想 ### 父–>子:i—>左孩子:2*i+1, 右孩子:2*i+2; 子–>父:i—>(i-1)/2; (i为下标元素) 1. 首先将待排序的数组构造成一个大项堆,此时,整个数组的最大值就是堆结构的顶端 2. 将顶端的数与末尾的数交换,此时,末尾的数为最大值,剩余待排序数组个数为n-1 3. 将剩余的n-1个数再构造成大项堆,再将顶端数与n-1位置的数交换,如此反复执行,便能得到有序数组 注意:升序用大项堆,降序就用小项堆(默认为升序) ## 二、大项堆排序案例 ## ### 1、流程 ### 1. 从最后一棵子树开始,从后往前调整 2. 每次调整,从上往下调整 3. 调整为大根堆 ### 2、讲解 ### 首先我们给定一个无序的序列,将其看做一个堆结构,一个没有规则的二叉树,将序列里的值按照从上往下,从左到右依次填充到二叉树中。 ![在这里插入图片描述][a24cb65a7da54803812a3c3e75be1955.png] 在这里1小于最大值子节点9,则交换1和9的位置 ![在这里插入图片描述][24876d8c934e45da96d8539eeafec288.png] 找到下一个非叶子节点3,用它和它的左右子节点进行比较,3小于最大值子节点9,交换3和9位置 ![在这里插入图片描述][41a123b33bc04edf85a4ff10ebb55358.png] 此时发现3小于6这个最大值子节点,我们需要进行调整,因此交换6和3的位置 ![在这里插入图片描述][8b16ce94b91b4037b3a454505f51013a.png] **此时我们就构造出来一个大根堆,下来进行排序** 首先将顶点元素9与末尾元素3交换位置,此时末尾数字为最大值。排除已经确定的最大元素,将剩下元素重新构建大根堆 **一次交换重构如图:** ![在这里插入图片描述][43f6c174d71249928e07db80648879d4.png] **最终排序结果:** ![在这里插入图片描述][0e460974e3e9495fb669dd2eb4f44667.png] ## 三、总结 ## 由此,我们可以归纳出堆排序算法的步骤: 1. 把无序数组构建成二叉堆。 2. 循环删除堆顶元素,移到集合尾部,调节堆产生新的堆顶。 堆排序是不稳定的排序,空间复杂度为O(1),平均的时间复杂度为O(nlogn),最坏情况下也稳定在O(nlogn) [1eb447601e5d4c1ab08af8d4612f50ad.png]: https://image.dandelioncloud.cn/pgy_files/images/2024/04/06/bd4b99e2829446b5917361b20e4e579d.png [1ffbc197510248578237bcdcce2dbdf7.png]: https://image.dandelioncloud.cn/pgy_files/images/2024/04/06/2eabc7b5b7af41018337bb2a350a58bf.png [a24cb65a7da54803812a3c3e75be1955.png]: https://image.dandelioncloud.cn/pgy_files/images/2024/04/06/ba3785030c1d4ecab70ec9951ea2eb3a.png [24876d8c934e45da96d8539eeafec288.png]: https://image.dandelioncloud.cn/pgy_files/images/2024/04/06/c33b2f70bc294c31a0e529466b723f5a.png [41a123b33bc04edf85a4ff10ebb55358.png]: https://image.dandelioncloud.cn/pgy_files/images/2024/04/06/a858a1d8d39e473ea1a4fdff7447a957.png [8b16ce94b91b4037b3a454505f51013a.png]: https://image.dandelioncloud.cn/pgy_files/images/2024/04/06/c77e6bf4a572499aa254ad2214b5cea6.png [43f6c174d71249928e07db80648879d4.png]: https://image.dandelioncloud.cn/pgy_files/images/2024/04/06/9c9610aff77e4948b67534d1b3aba68f.png [0e460974e3e9495fb669dd2eb4f44667.png]: https://image.dandelioncloud.cn/pgy_files/images/2024/04/06/61741f6fb60f49758f27b9b7169df2e8.png
相关 排序-堆排序 1.堆排序前言 前面博客中讲到简单选择排序,它在待排序的n个记录中选择一个最小的记录需要比较n-1次。本来这也可以理解,查找第一个数据需要比较这么多次是正常的,否则如何知 旧城等待,/ 2022年09月30日 06:45/ 0 赞/ 252 阅读
相关 【排序】堆排序 堆的定义 设有n个元素的序列 k1,k2,…,kn,当且仅当满足下述关系之一时,称之为堆。 ![图示][SouthEast] 解释:如果让满足以上条件的元素序列 (k 分手后的思念是犯贱/ 2022年06月18日 11:47/ 0 赞/ 285 阅读
相关 看懂堆排序——堆与堆排序(三) 看懂堆排序——堆与堆排序(三) 看懂堆排序——堆与堆排序(三) 堆排序的基本思想 代码详解 偏执的太偏执、/ 2022年05月25日 06:52/ 0 赞/ 315 阅读
相关 排序——堆排序 堆排序代码 include <iostream> using namespace std; include <stdio.h> in 墨蓝/ 2022年05月21日 12:05/ 0 赞/ 279 阅读
相关 堆排序 什么是堆排序,堆排序能解决什么问题? 在排序的过程中,不能把进行排序的过程中,得一些信息保留下来吗?来加快排序的速度吗?答案是可以的。通过利用完全二叉堆的结构来保留信息。 迷南。/ 2021年10月29日 07:20/ 0 赞/ 387 阅读
相关 堆和堆排序 堆排序 堆排序基本介绍 1. 堆排序是利用堆这种数据结构而设计的一种排序算法,堆排序是一种选择排序,它的最坏,最好,平均时间复 杂度均为 O(nlogn),它也 柔光的暖阳◎/ 2021年10月19日 21:12/ 0 赞/ 425 阅读
相关 堆排序 文章目录 一、堆排序介绍 二、如何进行堆排序 一、堆排序介绍 百度百科: 堆排序(Heapsort)是指利用堆积树 我会带着你远行/ 2021年10月18日 16:46/ 0 赞/ 373 阅读
相关 排序-堆排序 [2019独角兽企业重金招聘Python工程师标准>>> ][2019_Python_] ![hot3.png][] 在说明堆排序的过程前得先了解什么是堆: 先看下图(来源 清疚/ 2021年09月20日 03:22/ 0 赞/ 456 阅读
相关 堆排序 堆排序的特点是:在排序过程中,将待排序数组看成是一棵完全二叉树的顺序存储结构,利用完全二叉树中父结点和子结点之间的内在关系,在当前无序区中选择关键字最大(或最小) 不念不忘少年蓝@/ 2021年09月17日 00:16/ 0 赞/ 476 阅读
还没有评论,来说两句吧...