news 2026/7/1 10:07:26

简单堆和桶排序(自用)

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
简单堆和桶排序(自用)

一、 堆: 了解下就好


(1)堆是完全二叉树的结构
什么是完全二叉树:

1.只允许最后一行不满

2.最后一行必须从左往右排,中间不能有间隔


(2)堆序性

1.小根堆,父节点都要更小

2.大根堆,父节点都要更大


(3)堆的存储,因为是完全二叉树,所以可以根据层序遍历,来得到一个数组,此时,父节点为i时,左右子节点一定为2i+1/2


(4)堆有两个基本操作:

1.上滤,通常用于插入新元素到根中时,向上调整位置时
2.下滤(因为必须要满足堆序性的话,所以对不满足的要操作),把根节点向下调整的操作叫下滤


(5)自顶向下建堆法:

1.插入堆

2.上滤


(6)自下而上建堆法:

对每个父节点进行下滤(从最下面的父节点开始)--复杂度O(N)
(7)应用

1.优先队列:弹出最小元素--可以用来实现堆排序,用大根堆排序完,弹出的是正序,小根堆反

2.插入:就是上滤


java中常见写法

最大堆:(Lamda)

PriorityQueue<Integer> maxHeap = new PriorityQueue<>((a, b) -> b - a);

最小堆:

一般直接这么写就行

PriorityQueue<Integer> small_stack = new PriorityQueue<>();

lamda

二、桶排序

例题:前K个高频元素

class Solution { public int[] topKFrequent(int[] nums, int k) { // 第一步:统计每个元素的出现次数 Map<Integer, Integer> cnt = new HashMap<>(); for (int x : nums) { cnt.merge(x, 1, Integer::sum); // cnt[x]++ } int maxCnt = Collections.max(cnt.values()); // 第二步:把出现次数相同的元素,放到同一个桶中 List<Integer>[] buckets = new ArrayList[maxCnt + 1]; Arrays.setAll(buckets, _ -> new ArrayList<>()); for (Map.Entry<Integer, Integer> e : cnt.entrySet()) { buckets[e.getValue()].add(e.getKey()); } // 第三步:倒序遍历 buckets,把出现次数前 k 大的元素加入答案 int[] ans = new int[k]; int j = 0; for (int i = maxCnt; i >= 0 && j < k; i--) { // 注意题目保证答案唯一,一定会出现某次循环结束后 j 恰好等于 k 的情况 for (int x : buckets[i]) { ans[j++] = x; } } return ans; } }
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/30 14:52:14

USB标准发展历程简述,一文快速了解

从“插三次”到一缆通万物&#xff1a;USB进化史全解析你还记得第一次把U盘插进电脑时的场景吗&#xff1f;十次有八次是反的&#xff0c;硬生生把一个简单的操作变成了一场耐心测试。而今天&#xff0c;我们已经习惯了随手一插就能充电、传文件、连显示器——这一切的背后&…

作者头像 李华
网站建设 2026/6/26 7:57:37

如何提升DeepSeek-R1-Distill-Qwen-1.5B响应质量?系统提示使用规范

如何提升DeepSeek-R1-Distill-Qwen-1.5B响应质量&#xff1f;系统提示使用规范 1. DeepSeek-R1-Distill-Qwen-1.5B模型介绍 DeepSeek-R1-Distill-Qwen-1.5B是DeepSeek团队基于Qwen2.5-Math-1.5B基础模型&#xff0c;通过知识蒸馏技术融合R1架构优势打造的轻量化版本。其核心设…

作者头像 李华
网站建设 2026/7/1 0:36:37

手机自动化新玩法!Open-AutoGLM结合WiFi远程调试

手机自动化新玩法&#xff01;Open-AutoGLM结合WiFi远程调试 1. 引言&#xff1a;让AI真正“接管”你的手机 在智能手机功能日益复杂的今天&#xff0c;用户每天需要重复大量操作&#xff1a;刷短视频、查天气、下单外卖、回复消息……这些任务虽然简单&#xff0c;却消耗着宝…

作者头像 李华
网站建设 2026/7/1 18:34:33

静态功耗下同或门的稳定性问题快速理解

同或门在低功耗设计中的“隐性崩溃”&#xff1a;静态功耗下的输出稳定性危机你有没有遇到过这样的情况&#xff1f;电路功能仿真完全正确&#xff0c;时序收敛良好&#xff0c;芯片流片回来后却发现——系统偶尔会莫名其妙地误唤醒、状态丢失&#xff0c;甚至在深度睡眠中悄然…

作者头像 李华
网站建设 2026/7/1 8:23:05

SGLang GPU利用率低?多请求共享机制优化实战

SGLang GPU利用率低&#xff1f;多请求共享机制优化实战 1. 引言&#xff1a;SGLang 推理框架的性能挑战 随着大语言模型&#xff08;LLM&#xff09;在生产环境中的广泛应用&#xff0c;推理服务的效率问题日益凸显。尽管硬件算力持续提升&#xff0c;但在实际部署中&#x…

作者头像 李华
网站建设 2026/7/1 20:35:15

高保真语音合成新选择|Supertonic设备端TTS深度体验

高保真语音合成新选择&#xff5c;Supertonic设备端TTS深度体验 1. 引言&#xff1a;为什么需要设备端TTS&#xff1f; 在智能硬件、边缘计算和隐私敏感型应用快速发展的今天&#xff0c;文本转语音&#xff08;Text-to-Speech, TTS&#xff09;技术正从“云端主导”向“设备…

作者头像 李华