普通队列遵照先进先出(FIFO)的规则,而优先队列虽然也叫队列,规则有所不一样:web
优先队列能够用下面几种数据结构来实现:数组
若是用线性数据结构来实现优先级队列,则时间复杂度均为 O(n)。而若是用二叉堆来实现,时间复杂度能够提升到 O(logn)。下面以二叉堆为例。数据结构
二叉堆有两个限制:svg
根据二叉堆上面的性质,能够用一个数组来保存二叉堆中的结点。其中,对于数组中任一个秩为 x 的元素,其对应二叉树中,父子结点的秩分别为:.net
二叉堆的构建,能够参考 这里。xml