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

今天跟着左程云算法课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);
		}
	}
相关推荐
网易独家音乐人Mike Zhou3 小时前
【卡尔曼滤波】数据预测Prediction观测器的理论推导及应用 C语言、Python实现(Kalman Filter)
c语言·python·单片机·物联网·算法·嵌入式·iot
搬砖的小码农_Sky6 小时前
C语言:数组
c语言·数据结构
Swift社区7 小时前
LeetCode - #139 单词拆分
算法·leetcode·职场和发展
Kent_J_Truman7 小时前
greater<>() 、less<>()及运算符 < 重载在排序和堆中的使用
算法
先鱼鲨生8 小时前
数据结构——栈、队列
数据结构
一念之坤8 小时前
零基础学Python之数据结构 -- 01篇
数据结构·python
IT 青年8 小时前
数据结构 (1)基本概念和术语
数据结构·算法
熬夜学编程的小王8 小时前
【初阶数据结构篇】双向链表的实现(赋源码)
数据结构·c++·链表·双向链表
Dong雨8 小时前
力扣hot100-->栈/单调栈
算法·leetcode·职场和发展
SoraLuna8 小时前
「Mac玩转仓颉内测版24」基础篇4 - 浮点类型详解
开发语言·算法·macos·cangjie