zoukankan      html  css  js  c++  java
  • 关于priority_queue运算符重载的问题

    需求是将结点指针存入优先级队列,想自定义优先级规则,但是好几种方法都报错,只有一种可以,代码如下:

    struct ListNode {
        int val;
        ListNode *next;
        ListNode(int x) : val(x), next(NULL) {}
    };
    
    struct compare {
        bool operator()(const ListNode* a, const ListNode* b) const
        {   return a->val > b->val;     }
    };
    
    void test3()
    {
        ListNode* p1 = new ListNode(67);
        ListNode* p2 = new ListNode(29);
        ListNode* p3 = new ListNode(32);
        priority_queue<ListNode*, vector<ListNode*>, compare> pq;
        pq.push(p1);
        pq.push(p2);
        pq.push(p3);
    
        for(int i = 0; i < 3; ++i) {
            cout << pq.top()->val << endl;
            pq.pop();
        }
    }

    报错写法一:

    struct ListNode {
        int val;
        ListNode *next;
        ListNode(int x) : val(x), next(NULL) {}
    };
    
    struct compare {
        bool operator()(const ListNode& a, const ListNode& b) const
        {   return a.val > b.val;     }
    };
    
    void test3()
    {
        ListNode* p1 = new ListNode(67);
        ListNode* p2 = new ListNode(29);
        ListNode* p3 = new ListNode(32);
        priority_queue<ListNode, vector<ListNode>, compare> pq;
        pq.push(*p1);
        pq.push(*p2);
        pq.push(*p3);
    
        for(int i = 0; i < 3; ++i) {
            cout << pq.top().val << endl;
            pq.pop();
        }
    }

    报错写法二:

    struct ListNode {
        int val;
        ListNode *next;
        ListNode(int x) : val(x), next(NULL) {}
    };
    
    struct compare {
        bool operator()(const ListNode a, const ListNode b) const
        {   return a.val > b.val;     }
    };
    
    void test3()
    {
        ListNode* p1 = new ListNode(67);
        ListNode* p2 = new ListNode(29);
        ListNode* p3 = new ListNode(32);
        priority_queue<ListNode, vector<ListNode>, compare> pq;
        pq.push(p1);
        pq.push(p2);
        pq.push(p3);
    
        for(int i = 0; i < 3; ++i) {
            cout << pq.top().val << endl;
            pq.pop();
        }
    }

    希望熟悉这块的大佬可以指教一下

  • 相关阅读:
    Nginx日志定时切割脚本
    阿里大于短信接口
    阿里云Linux系统挂载数据盘
    阿里云 OSS+CDN
    值得一学的几条谷歌搜索技巧
    【转】makefile语法规则
    【转】GCC使用简介
    网络编程中常见地址结构与转换(IPv4/IPv6)
    【转】adns解析库——域名解析实例(C++、linux)
    【转】什么是自动化测试
  • 原文地址:https://www.cnblogs.com/joker1937/p/12287651.html
Copyright © 2011-2022 走看看