AtNtN 2022-05-24 18:51 采纳率: 100%
浏览 84
已结题

关于c++用lambda表达式自定义优先级队列出错,如何解决?

这样写,正确创建优先级队列
class mycomparison {
    public:
        bool operator()(const pair<int, int>& lhs, const pair<int, int>& rhs) {
            return lhs.second > rhs.second;
        }
    };

    vector<int> topKFrequent(vector<int>& nums, int k) {
        priority_queue<pair<int,int>,vector<pair<int,int>>,mycomparison>pri_que;
这样写 编译器报错,我的lambda表达式写错了吗?
        priority_queue<pair<int,int>,vector<pair<int,int>>,[](pair<int,int>&map1,pair<int,int>&map2)
        {return map1.second>map2.second;} >pri_que;
错误信息:
 error: a lambda expression cannot appear in this context
 priority_queue<pair<int,int>,vector<pair<int,int>>,[](pair<int,int>&map1,pair<int,int>&map2)
  • 写回答

2条回答 默认 最新

  • 关注

    构造方法用错了,你l放ambda的地方应该放functype而不是func本身:

    #include <queue>
    #include <vector>
    
    auto main() -> int
    {
        std::priority_queue<std::pair<int, int>, std::vector<std::pair<int, int>>,
                            std::function<bool(std::pair<int, int> & map1,
                                               std::pair<int, int> & map2)>>
        pri_que([](std::pair<int, int> &map1, std::pair<int, int> &map2) -> bool {
            return map1.second > map2.second;
        });
    }
    
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

问题事件

  • 系统已结题 6月6日
  • 已采纳回答 5月29日
  • 创建了问题 5月24日