热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

堆排序递归和非递归

在了解堆排序之前,基本的二叉树的概念是需要知道的完全二叉树:叶子节点在最后一层或者次一层,且节点从左往右连续大根堆:任何

在了解堆排序之前,基本的二叉树的概念是需要知道的


完全二叉树:叶子节点在最后一层或者次一层,且节点从左往右连续

大根堆:任何根节点都比他的左右子节点都要大

i为节点在数组中的索引,求节点的父节点:(i - 1) / 2, 求节点的左节点 i * 2 + 1,求节点的右节点 i * 2 + 2

在构建一个堆之前,我们需要先把他们的左右节点构建成堆,所以我们从下往上依次构建堆,由于叶子节点是没有子节点的,所以从最后一个节点的父节点开始构建,想画个个图,可是实力实在不允许那就都放在代码中吧,老铁干了这段代码,先写递归的吧,递归毕竟理解起来简单。

//测试方法&#64;Testpublic void test() {int size &#61; 50;int[] array &#61; new int[size];for (int i &#61; 0; i < size; i&#43;&#43;) {array[i] &#61; (int) (Math.random() * 100);}heapify2(array);System.out.println(Arrays.toString(array));}//堆排public void heapify2(int[] array) {if (array &#61;&#61; null || array.length < 2) {return;}//最后一个节点的父节点int parentNode &#61; (array.length - 2) / 2;//进行堆排for (int i &#61; parentNode; i >&#61; 0; i--) {sift2(array, i, array.length - 1);}//交换最后一个数和第一个数,交换后最大的数到最后&#xff0c;下次堆排的时候&#xff0c;最后一个数就不许算进去了for (int i &#61; array.length - 1; i > 0 ; i--) {swap(array, 0, i);sift2(array, 0, i - 1);}}/*** &#64;Description 递归写法*/public void sift2(int[] array, int currentNode, int length) {//左节点int left &#61; currentNode * 2 &#43; 1;//右节点int right &#61; currentNode * 2 &#43; 2;//如果左右节点有比当前节点要大的节点&#xff0c;后面是需要以这个节点进行堆排的int max &#61; currentNode;//左节点不能超过数组的最大索引if (left <&#61; length && array[left] > array[max]) {max &#61; left;}if (right <&#61; length && array[right] > array[max]) {max &#61; right;}//如果发生交换&#xff0c;我们就需要进行堆排了if (max !&#61; currentNode) {swap(array, max, currentNode);//由于max指向的索引是最大的&#xff0c;和currentNode交换后&#xff0c;max现在指向的值就是currentNode的值了sift2(array, max, length);}}

最主要的就是这个sift,通过不断交换&#xff0c;来达到大根堆的效果&#xff0c;接着就是非递归的写法&#xff0c;其实和递归的思想一样&#xff0c;我们交换后就以交换的节点来进行堆排

/*** &#64;Description 非递归写法*/public void sift1(int[] array, int currentNode, int length) {//这个tmp就是当前需要堆排的节点&#xff0c;如果交换了&#xff0c;我们就让这个tmp等于交换的位置&#xff0c;来达到往下移一层int tmp &#61; currentNode;//左节点int j &#61; currentNode * 2 &#43; 1;while (j <&#61; length) {//比较左右大小if (j &#43; 1 <&#61; length && array[j &#43; 1] > array[j]) {j &#61; j &#43; 1;}//由于左右已经进行比较了&#xff0c;所以我们只要于最大的比较if (array[tmp] < array[j]) {swap(array, tmp, j);//tmp往下移一层&#xff0c;tmp变成下一次需要堆排的节点tmp &#61; j;//j接着等于需要堆排的左节点j &#61; tmp * 2 &#43; 1;} else {break;}}}

推荐阅读
  • Android自定义控件绘图篇之Paint函数大汇总
    本文介绍了Android自定义控件绘图篇中的Paint函数大汇总,包括重置画笔、设置颜色、设置透明度、设置样式、设置宽度、设置抗锯齿等功能。通过学习这些函数,可以更好地掌握Paint的用法。 ... [详细]
  • Java容器中的compareto方法排序原理解析
    本文从源码解析Java容器中的compareto方法的排序原理,讲解了在使用数组存储数据时的限制以及存储效率的问题。同时提到了Redis的五大数据结构和list、set等知识点,回忆了作者大学时代的Java学习经历。文章以作者做的思维导图作为目录,展示了整个讲解过程。 ... [详细]
  • 本文介绍了H5游戏性能优化和调试技巧,包括从问题表象出发进行优化、排除外部问题导致的卡顿、帧率设定、减少drawcall的方法、UI优化和图集渲染等八个理念。对于游戏程序员来说,解决游戏性能问题是一个关键的任务,本文提供了一些有用的参考价值。摘要长度为183字。 ... [详细]
  • JVM:33 如何查看JVM的Full GC日志
    1.示例代码packagecom.webcode;publicclassDemo4{publicstaticvoidmain(String[]args){byte[]arr ... [详细]
  • Iamtryingtomakeaclassthatwillreadatextfileofnamesintoanarray,thenreturnthatarra ... [详细]
  • 本文分享了一个关于在C#中使用异步代码的问题,作者在控制台中运行时代码正常工作,但在Windows窗体中却无法正常工作。作者尝试搜索局域网上的主机,但在窗体中计数器没有减少。文章提供了相关的代码和解决思路。 ... [详细]
  • 本文介绍了一个Java猜拳小游戏的代码,通过使用Scanner类获取用户输入的拳的数字,并随机生成计算机的拳,然后判断胜负。该游戏可以选择剪刀、石头、布三种拳,通过比较两者的拳来决定胜负。 ... [详细]
  • 本文介绍了Redis的基础数据结构string的应用场景,并以面试的形式进行问答讲解,帮助读者更好地理解和应用Redis。同时,描述了一位面试者的心理状态和面试官的行为。 ... [详细]
  • 本文讨论了在openwrt-17.01版本中,mt7628设备上初始化启动时eth0的mac地址总是随机生成的问题。每次随机生成的eth0的mac地址都会写到/sys/class/net/eth0/address目录下,而openwrt-17.01原版的SDK会根据随机生成的eth0的mac地址再生成eth0.1、eth0.2等,生成后的mac地址会保存在/etc/config/network下。 ... [详细]
  • 开源Keras Faster RCNN模型介绍及代码结构解析
    本文介绍了开源Keras Faster RCNN模型的环境需求和代码结构,包括FasterRCNN源码解析、RPN与classifier定义、data_generators.py文件的功能以及损失计算。同时提供了该模型的开源地址和安装所需的库。 ... [详细]
  • STL迭代器的种类及其功能介绍
    本文介绍了标准模板库(STL)定义的五种迭代器的种类和功能。通过图表展示了这几种迭代器之间的关系,并详细描述了各个迭代器的功能和使用方法。其中,输入迭代器用于从容器中读取元素,输出迭代器用于向容器中写入元素,正向迭代器是输入迭代器和输出迭代器的组合。本文的目的是帮助读者更好地理解STL迭代器的使用方法和特点。 ... [详细]
  • 1.ArrayList是实现了基于动态数组的数据结构,LinkedList基于链表的数据结构。 2.对于随机访问get和set,ArrayList优于LinkedList,因为Ar ... [详细]
  • 很多时候在注册一些比较重要的帐号,或者使用一些比较重要的接口的时候,需要使用到随机字符串,为了方便,我们设计这个脚本需要注意 ... [详细]
  • Python 可视化 | Seaborn5 分钟入门 (六)——heatmap 热力图
    微信公众号:「Python读财」如有问题或建议,请公众号留言Seaborn是基于matplotlib的Python可视化库。它提供了一个高级界面来绘制有吸引力的统计图形。Seabo ... [详细]
  • 初识java关于JDK、JRE、JVM 了解一下 ... [详细]
author-avatar
理想压力正比_635
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有