news 2026/5/7 13:51:47

堆排序和topk问题

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
堆排序和topk问题

系列文章目录


文章目录

  • 系列文章目录
  • 前言
  • 一、堆排序定义
  • 二、时间复杂度
  • 三、实现思路
    • a.注意(升/降)
  • 四、topk问题

前言

常见的基本排序算法有冒泡、选择、插入,但效率太低。
堆排序和快速排序算法则是相对高效的算法。这篇主要先介绍堆排序


一、堆排序定义

堆排序就是借助(大/小)堆的特性,实现的快速排序

二、时间复杂度

时间复杂度:N * log2
本质就是建堆后,借助堆来调整N个数的位置,每次调整时间为堆高度log2

三、实现思路

(以小堆为例)

  1. 先将数据建小堆,此时堆顶是最小值。
  2. 将堆顶元素与数组末尾的元素交换,此时最小值被放到数组末尾。
  3. 将堆的有效长度-1,末尾元素视为已排序,不参与后续调整。
  4. 对堆顶的元素进行向下调整,使其重新满足小堆的特性
  5. 重复上述过程,直到堆的有效长度为1
//实现堆排序————时间复杂度:N * logN (一次向下调整是N, 执行N次)voidHeapSort(int*a,intn){//1、建堆for(inti=(n-1-1)/2;i>=0;i--)//需要从最后一个节点的父亲节点,开始向下调整{AdjustDown(a,n,i);}//2、将排序好的最小值,排出堆排序的范围intend=n-1;//3、再一直对根节点实现向下调整while(end>0){swap(&a[0],&a[end]);//再次选择最小的值AdjustDown(a,end,0);end--;}}

至此,实现了数组的降序排列

a.注意(升/降)

排升序,建大堆
排降序,建小堆

因为每次堆顶会和数组末尾的元素交换


四、topk问题

N个数中找出最大或最小的前K个数?

最优方案:建立一个K的数的堆。
如果想找K个最大数就建小堆,想找K个最小数就建大堆
(以小堆为例)

遍历N-K个数,凡是比堆顶大的数就替换堆顶数据,进堆向下调整。
(因为堆顶的数总是较小的)最后剩下的k个数就是前K个最大的数。

前K个最小的数同理可得。

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

Java毕设项目推荐-基于springboot的幼儿园管理系统的设计与实现家校互动(通知推送、留言沟通)、膳食营养规划【附源码+文档,调试定制服务】

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

作者头像 李华
网站建设 2026/5/7 13:12:42

Java毕设项目推荐-基于springboot小区团购管理设计与实现基于springboot的社区团购系统的设计与实现【附源码+文档,调试定制服务】

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

作者头像 李华
网站建设 2026/5/1 12:25:23

《AI应用架构师:在AI驱动数字转型的浪潮中破浪前行》

AI应用架构师:在AI驱动数字转型的浪潮中破浪前行 引言:为什么你的AI项目总是“翻车”? 凌晨三点,某零售企业的技术总监盯着电脑屏幕发呆——他们花了120万采购的AI推荐系统上线3个月,用户转化率没涨反降,…

作者头像 李华
网站建设 2026/5/5 22:25:17

android kotlinx.serialization用法和封装全解

替代Gson、fastJson等传统java的json解析工具。抛弃传统的反射类解析字段,利用kotlin的inlinereified特性和android可以预编译的特点,在编译阶段的时候,还原最后的类型,来实现的json序列化与反序列化。 性能效率:不做评…

作者头像 李华
网站建设 2026/5/6 4:01:04

Python CGI 编程

Python CGI 编程 引言 CGI(Common Gateway Interface,通用网关接口)是一种网络服务器与执行程序之间进行通信的协议。Python作为一种功能强大、易学易用的编程语言,在CGI编程中得到了广泛应用。本文将详细介绍Python CGI编程的相关知识,包括Python CGI的基础概念、环境搭…

作者头像 李华