普林斯顿算法中级笔记7(优先队列)


什么是优先队列

一个普通队列在删除时,删除最大或者最小的元素

方法定义
方法
MaxPQ() 创建一个空队列
MaxPQ(Key[] a) 创建一个具有初始化数据的队列
void insert(Key v) 插入
Key delMax() 删除最大元素,并返回该元素
boolean isEmpty() 是否为空
Key max() 返回最大元素
int size() 返回队列大小

二叉树(后面将之成为堆)

节点为N的二叉树,高度为lgN

大(小)顶堆

每一个父节点都不小于它的子节点

数组实现二叉树结构

以索引1作为起始,1的位置存储根结点,节点n的子节点为2n,2n+1,节点k的子节点为k/2


屏幕快照 2018-08-14 下午4.55.41.png
节点的提升

首先针对单个节点进行处理
循环比较,它与它的父节点,若大于父节点则进行交换。

private void swim(int k)
{
 while (k > 1 && less(k/2, k))
 {
 exch(k, k/2);
 k = k/2;
 }
}
节点的插入
public void insert(Key x)
{
 pq[++N] = x;
 swim(N);
}
节点的下降

若节点小于子节点,则将次节点循环下降

private void sink(int k)
{
 while (2*k <= N)
 {
 int j = 2*k;
 if (j < N && less(j, j+1)) j++;
 if (!less(k, j)) break;
 exch(k, j);
 k = j;
 }
}
删除最大元素

将最顶部元素与末尾元素交换,而后输出末尾元素,并且将交换后的顶部元素再进行sink

public Key delMax()
{
 Key max = pq[1];
 exch(1, N--);
 sink(1);
 pq[N+1] = null;
 return max;
} 
算法复杂度分析
方法 复杂度
insert logN
delMax logN

堆排序

思路
  • 构造一个大顶堆,取堆顶元素,将堆顶元素与最后一个元素交换。
  • 将剩余元素重新构成一个大顶堆
代码实现
public class Heap
{
 public static void sort(Comparable[] a)
 {
 int N = a.length;
 for (int k = N/2; k >= 1; k--)
 sink(a, k, N);
 while (N > 1)
 {
 exch(a, 1, N);
 sink(a, 1, --N);
 }
 }
}
算法复杂度与特点分析
  • 堆排序的算法复杂度为2NlogN,最坏为2NlogN,最好为NlogN
  • 它是一个占用额外空间很小的算法
  • 它是一个不稳定算法
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 1 序 2016年6月25日夜,帝都,天下着大雨,拖着行李箱和同学在校门口照了最后一张合照,搬离寝室打车去了提前租...
    RichardJieChen阅读 5,165评论 0 12
  • 课程介绍 先修课:概率统计,程序设计实习,集合论与图论 后续课:算法分析与设计,编译原理,操作系统,数据库概论,人...
    ShellyWhen阅读 2,362评论 0 3
  • 1 初级排序算法 排序算法关注的主要是重新排列数组元素,其中每个元素都有一个主键。排序算法是将所有元素主键按某种方...
    深度沉迷学习阅读 1,453评论 0 1
  • 从康定情歌往雅安方向走,途径泸定!停留了一个晚上,目睹和体验了飞夺泸定桥的惊悚!走在桥上一抖一抖的,深怕一个踩空掉...
    CindyZhong阅读 369评论 0 0
  • “本文参加#未完待续,就要表白#活动,本人承诺,文章内容为原创,且未在其他平台发表过。” 张爱玲说:“短的是生命,...
    fantasy2me阅读 888评论 3 3