数据结构(8.4_2)——堆排序

堆(Heap)

大根堆:完全二叉树中,根>=左、右

小根堆:完全二叉树中,根<=左、右

相关知识------二叉树的顺序存储

建立大根堆

i的左孩子:2i

i的右孩子:2i+1

i的父结点:i/2

思路:把所有的非终端结点都检查一遍,是否满足大堆根的要求,如果不满足,则进行调整

先处理编号最大的根

接下来处理3号结点

接下来依次处理剩下的根结点

处理完53结点后需要将更下的元素"下坠"

建立大根堆(代码)

基于大根堆进行排序

每一趟将堆定元素加入有序子序列(与待排序序列中的最后一个元素交换),交换完后调整排序序列,再次构成一个大根堆

第一趟

第二趟

.....n-1次排序后

大根堆:递增序列

小根堆:递减序列

基于大根堆进行排序 (代码)

算法效率分析

建堆的时间复杂度:O(n)

下坠的时间复杂度:

稳定性

总结:

练习:

相关推荐
koping_wu12 分钟前
【Zookeeper】数据结构、集群原理、选举机制
数据结构·zookeeper·java-zookeeper
hweiyu0014 分钟前
数据结构:线段树
数据结构
CQ_YM16 分钟前
数据结构之哈希表
数据结构·算法·哈希算法·哈希表
FMRbpm37 分钟前
顺序表实现队列
数据结构·c++·算法·新手入门
飞天狗11138 分钟前
G. Mukhammadali and the Smooth Array
数据结构·c++·算法
CQ_YM42 分钟前
数据结构之树
数据结构·算法·
小李小李快乐不已2 小时前
哈希表理论基础
数据结构·c++·哈希算法·散列表
AuroraWanderll2 小时前
C++11(二)核心突破:右值引用与移动语义(上)
c语言·数据结构·c++·算法·stl
CoderYanger2 小时前
第 479 场周赛Q1——3769. 二进制反射排序
java·数据结构·算法·leetcode·职场和发展
sin_hielo2 小时前
leetcode 1925
数据结构·算法·leetcode