【算法与数据结构复习】| 堆结构和堆排序

今天跟着左程云算法课25复习了堆结构和堆排序相关内容。

对于一个数据nums,我们可以将其理解为一个完全二叉树。完全二叉树就是指按照层次来添加数,每层满了再往下一层添加。对于数组中下标i,其父节点的下标为(i-1)/2,左孩子的下标为2*i+1,右孩子的下标为2*i+2。

在堆结构中有两个重要的步骤:1)i位置的数,向上调整大根堆。2)i位置的数,向下调整大根堆,当前堆大小为size。

一、向上调整大根堆

比较好理解,比自己的父节点大就一直往上和自己的父节点置换。

java 复制代码
	public static void heapInsert(int[] arr, int i) {
		while (arr[i] > arr[(i - 1) / 2]) {
			swap(arr, i, (i - 1) / 2);
			i = (i - 1) / 2;
		}
	}
二、向下调整大根堆

选出左右孩子中比较大的一个,和当前i节点进行比较(要判断左右孩子是否存在,用下标和size进行比较)。若左右孩子有比i节点大的,则往下置换。一直置换到i节点比自己左右孩子都大的情况。

java 复制代码
	public static void heapify(int[] arr, int i, int size) {
		int l = i * 2 + 1;
		while (l < size) {
			// 有左孩子,l
			// 右孩子,l+1
			// 评选,最强的孩子,是哪个下标的孩子
			int best = l + 1 < size && arr[l + 1] > arr[l] ? l + 1 : l;
			// 上面已经评选了最强的孩子,接下来,当前的数和最强的孩子之前,最强下标是谁
			best = arr[best] > arr[i] ? best : i;
			if (best == i) {
				break;
			}
			swap(arr, best, i);
			i = best;
			l = i * 2 + 1;
		}
	}
三、堆排序

堆排序分为两个步骤:1)建立大根堆;2)将根于数组最后一位数进行置换,然后将置换后的根节点向下调整。重复上述过程。

建立大根堆可以从顶向下建立,也可以自下而上建立。前者使用heapInsert,后者使用heapify。

两种堆排序:
java 复制代码
	// 从顶到底建立大根堆,O(n * logn)
	// 依次弹出堆内最大值并排好序,O(n * logn)
	// 整体时间复杂度O(n * logn)
	public static void heapSort1(int[] arr) {
		int n = arr.length;
		for (int i = 0; i < n; i++) {
			heapInsert(arr, i);
		}
		int size = n;
		while (size > 1) {
			swap(arr, 0, --size);
			heapify(arr, 0, size);
		}
	}

	// 从底到顶建立大根堆,O(n)
	// 依次弹出堆内最大值并排好序,O(n * logn)
	// 整体时间复杂度O(n * logn)
	public static void heapSort2(int[] arr) {
		int n = arr.length;
		for (int i = n - 1; i >= 0; i--) {
			heapify(arr, i, n);
		}
		int size = n;
		while (size > 1) {
			swap(arr, 0, --size);
			heapify(arr, 0, size);
		}
	}
相关推荐
2301_816651226 分钟前
嵌入式C++低功耗设计
开发语言·c++·算法
机器学习之心17 分钟前
PSO-LightGBM-ABKDE粒子群算法优化轻量级梯度提升机自适应带宽核密度估计多变量回归区间预测Matlab实现
算法·matlab·回归·abkde·自适应带宽核密度估计·pso-lightgbm·粒子群算法优化轻量级梯度提升机
qq_4160187232 分钟前
分布式缓存一致性
开发语言·c++·算法
CoovallyAIHub36 分钟前
多 Agent 手术推理框架:Agent 辩论+RAG 补上手术知识,零样本超越监督基线 14.6 个百分点
算法·架构·机器人
干啥啥不行,秃头第一名40 分钟前
STL容器内部实现剖析
开发语言·c++·算法
Zarek枫煜40 分钟前
zig与c3的冒泡排序算法
算法
xiaoye-duck44 分钟前
《算法题讲解指南:动态规划算法--简单多状态dp问题》--13.删除并获得点数,14.粉刷房子
c++·算法·动态规划
老鼠只爱大米1 小时前
LeetCode经典算法面试题 #347:前 K 个高频元素(最小堆、桶排序、快速选择等多种实现方案详解)
算法·leetcode·堆排序·java面试题·桶排序·快速选择·topk
2401_831824961 小时前
内存泄漏检测与防范
开发语言·c++·算法
FluxMelodySun1 小时前
机器学习(二十五) 降维:主成分分析(PCA)及特征值分解
人工智能·算法·机器学习