平均情况、最好情况和最坏情况的时间复杂度都为O(nlog2n),即线性对数复杂度,不稳定的排序算法。
堆结构在 数据结构:二叉完全树(堆) 一文中进行了分析,接下来用代码来实现其几个关键操作:弹出、插入、取顶、上浮、下沉
堆操作实现
这里的实现以小根堆为例:
堆的基本操作接口定义:
弹出方法
弹出时将数组尾元素放到到数组首部,然后对数据首部(根节点)执行下沉操作即可。
插入方法
插入时将新元素放到数组尾部,然后对尾部元素执行上浮操作即可。
平均情况、最好情况和最坏情况的时间复杂度都为O(nlog2n),即线性对数复杂度,不稳定的排序算法。
堆结构在 数据结构:二叉完全树(堆) 一文中进行了分析,接下来用代码来实现其几个关键操作:弹出、插入、取顶、上浮、下沉
这里的实现以小根堆为例:
堆的基本操作接口定义:
弹出时将数组尾元素放到到数组首部,然后对数据首部(根节点)执行下沉操作即可。
插入时将新元素放到数组尾部,然后对尾部元素执行上浮操作即可。