自己动手实现优先级队列

来源:互联网 发布:matlab矩阵归一化函数 编辑:程序博客网 时间:2024/05/24 05:57

优先级队列是一种应用广泛的数据结构,例如可以用在dijsktra 算法中。我们这里使用deque来实现优先级队列,deque支持常数时间内随机访问以及首位添加和删除操作,非常适合用来实现优先级队列。
啥也不说了,上代码。

#include <deque>#include <limits>using namespace std;class PriorityQueue {public:    PriorityQueue() {        a.push_back(1);    }    void push(int val) {        a.pop_front();        a.push_front(val);        a.push_front(1);        heapfy(1);    }    int top() {        return a[1];    }    void pop() {        swap(a[1], a[a.size() - 1]);        a.pop_back();        heapfy(1);    }    int size() {        return a.size() - 1;    }private:    void heapfy(int beg) {        if (beg >= a.size()) return;        if ((beg<<1 >= a.size() || a[beg] >= a[beg<<1])             && (beg<<1 + 1 >= a.size() || a[beg] >= a[beg<<1 + 1])) return;        int l = numeric_limits<int>::min();        int r = numeric_limits<int>::min();        if (beg<<1 + 1 < a.size()) {            r = a[beg<<1 + 1];        }        if (beg<<1 < a.size()) {            l = a[beg<<1];        }        if (r >= l) {            if (r != numeric_limits<int>::min()) {                swap(a[beg<<1 + 1], a[beg]);                heapfy(beg<<1 + 1);            }        } else {            if (l != numeric_limits<int>::min()) {                swap(a[beg<<1], a[beg]);                heapfy(beg<<1);            }        }    }    deque<int> a;};
0 0
原创粉丝点击
热门问题 老师的惩罚 人脸识别 我在镇武司摸鱼那些年 重生之率土为王 我在大康的咸鱼生活 盘龙之生命进化 天生仙种 凡人之先天五行 春回大明朝 姑娘不必设防,我是瞎子 淘宝仅退款卖家不处理怎么办 淘宝申请退款卖家不处理怎么办 快递没收到货要退款怎么办 发票给了不给钱怎么办 付款后不给发票怎么办 供货商不给发票怎么办 刚生过孩子太胖买衣服怎么办 黑色牛仔裤洗的发白怎么办 蘑菇街手机丢了怎么办 黑衣服上全是白毛毛怎么办 支付宝注销了钱怎么办 网上买东西手机号写错了怎么办 二类工资卡过万怎么办 淘宝发货地址写错怎么办 淘宝发货地址写错了怎么办 淘宝不能代付了怎么办 支付宝付款码被盗刷怎么办 地方选举追究不到相关责任人怎么办 天正建筑画个直线找不到怎么办 Wi-Fi模块不支持多播怎么办? 魅族手机屏幕点不动怎么办 uc打开网页很慢怎么办 京东手机号码无法登录怎么办 织梦系统网站没收录怎么办 电脑开机出现一堆乱码怎么办 电脑文件夹出现乱码打不开怎么办 电脑出现f1和f2怎么办 电脑中韩文内容显示乱码怎么办 入驻shopee没身份证怎么办 液相色谱柱柱压降低怎么办 c18色谱柱堵了怎么办 色谱柱进空气了怎么办 宫颈评分只有3分怎么办 淘宝鞋子售后退货商家拒收怎么办 退货申通cp原因怎么办 运费险赔的少怎么办 淘宝卖游戏账号恶意退款怎么办 淘宝账号体检虚拟违规怎么办 京东虚拟单被骗怎么办 网络公选课挂科怎么办 淘宝评论被商家关闭怎么办?