news 2026/1/25 10:26:30

堆排序--自学笔记

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
堆排序--自学笔记

堆排序

学习目标

1.堆结构

2.堆排序思想

3.代码实现

4.复杂度分析

1.堆结构

定义

符合以下两个条件之一的完全二叉树

  • 根节点的值 >= 子节点的值,称为最大堆,或大顶堆
  • 根节点的值 <= 子节点的值,称为最小堆,或小顶堆

2.堆排序思想

3.代码实现

/** * 堆排序 * @param arr */publicstaticvoidheapSort(int[]arr){//堆排序第一步:初始化堆//这里选择构建大顶堆:从小到大排序buildMaxHeap(arr);//取数字,调整 循环//取出堆顶数字:与数组末尾元素交换//数组长度-1for(inti=arr.length-1;i>0;i--){swap(arr,0,i);//i也可以代表数组中可用的数字maxHeapify(arr,0,i);}}/** * 初始化堆(大顶堆) * @param arr */privatestaticvoidbuildMaxHeap(int[]arr){//构建堆第一步:从最后一个非叶子节点开始进行三人组比赛//也可以从arr.length - 1 开始,但它没有左右子节点,也会运算到arr.length / 2 - 1for(inti=arr.length/2-1;i>=0;i--){//大顶堆化maxHeapify(arr,i,arr.length);}}/** * 大顶堆化 * @param arr * @param i * @param heapSize */privatestaticvoidmaxHeapify(int[]arr,inti,intheapSize){//找到左右子节点intl=2*i+1;intr=2*i+2;intlargest=i;//不能越界if(l<heapSize&&arr[l]>arr[largest]){largest=l;}if(r<heapSize&&arr[r]>arr[largest]){largest=r;}if(largest!=i){//需要发生交换swap(arr,i,largest);//发生了交换 则交换下来的元素需要继续下沉maxHeapify(arr,largest,heapSize);}}privatestaticvoidswap(int[]arr,inta,intb){inttemp=arr[a];arr[a]=arr[b];arr[b]=temp;}

4.复杂度分析

215. 数组中的第K个最大元素 - 力扣(LeetCode)

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/1/18 1:03:02

AI论文助手推荐:8个高效工具实现自动降重与内容优化

在AI论文辅助工具领域&#xff0c;多款平台各具特色&#xff0c;涵盖降重、AIGC检测优化及论文撰写等核心功能。通过对8款主流工具的横向评测&#xff0c;结合实际测试结果与用户体验反馈&#xff0c;以下为综合性能排名&#xff08;评估维度包括处理效率、内容准确性及操作便捷…

作者头像 李华
网站建设 2026/1/19 11:35:01

动态规划(六)——分治优化DP 算法设计与分析 国科大

本文内容紧接动态规划&#xff08;五&#xff09;&#xff0c;讨论如何优化序列对齐算法Hirschberg算法上文最后提到的解决方案&#xff0c;是维护一个OPT矩阵&#xff0c;那么它的空间开销就变成了O(mn)&#xff0c;而Hirschberg 算法通过分治策略&#xff0c;将序列对齐问题的…

作者头像 李华
网站建设 2026/1/20 20:16:30

基于python的网上商城比价系统(源码+vue+前后端分离)

前言基于Python的网上商城比价系统是一种先进的应用程序&#xff0c;旨在帮助消费者在众多在线商城中快速找到性价比最高的商品。以下是对该系统的详细介绍&#xff1a; 一、系统背景与意义 随着电子商务的迅猛发展&#xff0c;网上商城已成为消费者购物的主要渠道。然而&#…

作者头像 李华
网站建设 2026/1/15 22:32:34

OpenMV识别物体结合WiFi传输的安防监控:项目实践

用OpenMV做智能安防&#xff1a;从目标识别到WiFi告警的实战全记录 最近在捣鼓一个“小而实用”的物联网项目&#xff1a;让一块小小的OpenMV摄像头&#xff0c;不仅能识别人和物体&#xff0c;还能在发现异常时立刻通过WiFi把图像发到手机上。听起来像高端货&#xff1f;其实…

作者头像 李华
网站建设 2026/1/25 2:48:59

计算机Java毕设实战-基于Java的旧物回收管理系统设计与实现基于springboot的旧物回收商城系统的设计与实现【完整源码+LW+部署说明+演示视频,全bao一条龙等】

博主介绍&#xff1a;✌️码农一枚 &#xff0c;专注于大学生项目实战开发、讲解和毕业&#x1f6a2;文撰写修改等。全栈领域优质创作者&#xff0c;博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java、小程序技术领域和毕业项目实战 ✌️技术范围&#xff1a;&am…

作者头像 李华