c++ priority_queue 存储自定义数据

//方法1,运算符重载
struct cmp1 {
    int x;

    cmp1(int a) { x = a; }

    bool operator<(const cmp1& a) const {
        return x < a.x;     //大根堆
    }
};

//方法2;重写仿函数
struct cmp2 {
    bool operator ()(cmp1 a, cmp1 b) {
        return a.x < b.x;           //大根堆
    }
};

//方法3
static bool cmp3(cmp1 a, cmp1 b) {
    return a.x > b.x;               //小根堆
}

void testPriorityQueue() {
    cmp1 a(1);
    cmp1 b(2);
    cmp1 c(3);
    //priority_queue<tmp1> q;                   //方法1,大根堆
    //priority_queue<tmp1,vector<tmp1>,cmp2>q;	//方法2,大根堆
    priority_queue<cmp1, vector<cmp1>, decltype(&cmp3)> q(cmp3);	//方法3,小根堆
    q.push(b);
    q.push(c);
    q.push(a);
    while(q.size()){
        cout << q.top().x << endl;
        q.pop();
    }
}
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
本版本与网上其他资源不同之处在于,此版本可进行编辑,搜索,已进行内容识别扫描。可全选,可编辑,可剪切文字。 部分目录如下: 目录 第一篇预备知识 第1 章C++ 编程技术...................................................... 3 1-1 C++与C 语言的区别................................................... 4 1-1-1 文件扩展名的改变,.............................................. 4 1-1-2 简化输入/输出手段.............................................. 5 1-1-3 数据型声明的改变,............................................ 5 1-1-4 动态内存分配运算符的使用....................................... 6 1-1-5 弓I 用(References) 型, ··················•················•"'''8 1-1-6 const 语义的扩展................................................ 9 1-1-7 指针声明型与对象型相一致.................................. 13 1-1-8 int 与char 不再等价............................................. 13 1-1-9 结构数据型的变化............................................ 13 1-1-10 数组和指针技术的不同......................................... 14 1-2 C++存储技术........................................................ 15 1-2 一I C++存储型.................................................. 15 I6I7 ..... .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. •. .• •. .• .. .. .. .. .. .. .. .. .. .. .. .. . 期 符存 饰生 修的 取象 存对 廿廿 I2I32 ~3 c c 1-3 C++ 函数技术........................................................ 19 1-3-1 的构造函数、析构函数与赋值函数,..... - ........ - .............. 19 1-3-2 在派生中实现的基本函数,................... _ ............... 29 1-3-3 内联函数技术,........ ................................... 30 3133 ..... .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. . 现 实 术的 技制 数机 函象 元对 友向 由 曰1. l -C 1 4 3337 ..... .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. . 术术 技技 承载 继重 的数 函 l4l44 3 ~ 3840 ..... .. .. .. .. .. .. •. .• .. .. .. .. .. .. .. .. .. .. .. •. .• .. •. .• •. •• .• .. .. .. .. .. .. .. .. .. •. •• .• . 术 技 术象 技抽 载和 重数 符函 算虚 运纯 l4l34 4 1-5 小结...............................................

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值