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

堆(Heap)

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

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

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

建立大根堆

i的左孩子:2i

i的右孩子:2i+1

i的父结点:i/2

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

先处理编号最大的根

接下来处理3号结点

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

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

建立大根堆(代码)

基于大根堆进行排序

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

第一趟

第二趟

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

大根堆:递增序列

小根堆:递减序列

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

算法效率分析

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

下坠的时间复杂度:

稳定性

总结:

练习:

相关推荐
single59422 分钟前
【综合算法学习】(第十篇)
java·数据结构·c++·vscode·学习·算法·leetcode
free_girl_fang41 分钟前
夯实根基之MySql从入门到精通(一)
java·数据结构·数据库·mysql
Lonelinessser1 小时前
数据结构——基础知识补充
数据结构
凡尘技术1 小时前
算法实现 - 快速排序(Quick Sort) - 理解版
java·数据结构·算法
wh233z1 小时前
Codeforces Round 981 (Div. 3) (A~F)
c语言·数据结构·c++·算法
字节卷动1 小时前
【牛客算法】某司面试算法题:循环右移二叉树
数据结构·算法·leetcode·面试·牛客
tang13897642 小时前
Python(数据结构2)
数据结构
Wangx_wang2 小时前
c++11新语法(上)
数据结构·c++·算法
知困勉行的Allen3 小时前
~C.库函数的介绍~
c语言·开发语言·数据结构·c++·学习方法
想做白天梦13 小时前
LeetCode(704)的二分查找 (简单)
数据结构·算法·leetcode