| |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
-> C++知识库 -> c++优先级队列priority_queue使用lambda表达式出错问题 -> 正文阅读 |
|
[C++知识库]c++优先级队列priority_queue使用lambda表达式出错问题 |
优先级队列简介优先级队列priority_queue,可以在队列中自定义数据的优先级, 让优先级高的排在队列前面优先出队。它具有队列的所有特性,包括队列的基本操作,只是在这基础上添加了内部的一个排序,它本质是一个堆实现的。 优先级队列的内部是大小顶堆实现的,弹出
基本操作有: empty( ) ?//判断一个队列是否为空 pop( ) ?//删除队顶元素 push( ) ?//加入一个元素 size( ) ?//返回优先队列中拥有的元素个数 top( ) ?//返回优先队列的队顶元素 优先队列的时间复杂度为O(logn),n为队列中元素的个数,其存取都需要时间。 ?叉堆是?种特殊的?叉树(完全?叉树),因为堆是基于完全二叉树,所以我们不需要用链式结构来表示,我们可以直接用数组存。 假设父节点的下表为parent,从父节点获取子节点: 小顶堆图示: 小顶堆的建立和删除都是?下沉?操作,添加做的是?上浮?操作。 大顶堆图示: 如上图所示,假设父节点的下标 parent=0,则其左子节点下标为Lchildren=2*parent+1。 右子节点下标为Rchildren=2*parent+2,如上示为例: ?般的链表?叉树,我们操作节点的指针,?在数组?我们把数组索引作为指针。 问题描述在c++17下,priority_queue优先级队列使用lambda表达式,可能遇到以下错误提示信息: error: a lambda expression cannot appear in this context。 测试创建了一个自定义的优先级队列,测试代码如下:
这段代码在c++20下面测试是ok的。附测试网站地址:GDB online Debugger | Compiler - Code, Compile, Run, Debug online C, C++ 换成c++17下测试: ?原因分析Your code is valid C++20 as written but invalid C++17 or earlyer. 在 C++20 之前闭包类型不是默认可构造的。在 C++20 中没有捕获的闭包类型是默认可构造的。 参考这个回答: 1.Lambda expressions are not allowed in unevaluated contexts (such as decltype) before C++20. 解决之道问题原因清楚了,如何解决?不能轻易的就换成c++20的工具链吧。方法还是有的,可以改为仿函数实现。定义一个myGreater仿函数解决:
如果使用
priority_queue()默认按照从小到大排列,less,最大堆(降序)。所以top()返回的是最大值而不是最小值。 使用greater<>后,数据从大到小排列,最小堆(升序),top()返回的就是最小值而不是最大值。 附,优先级队列的简单模拟实现(最大堆):
引用c++ 优先队列(priority_queue)_STATICHIT静砸的博客-CSDN博客_c++ 优先队列 什么是二叉堆?_韩师学子--小倪的博客-CSDN博客_二叉堆 |
|
C++知识库 最新文章 |
【C++】友元、嵌套类、异常、RTTI、类型转换 |
通讯录的思路与实现(C语言) |
C++PrimerPlus 第七章 函数-C++的编程模块( |
Problem C: 算法9-9~9-12:平衡二叉树的基本 |
MSVC C++ UTF-8编程 |
C++进阶 多态原理 |
简单string类c++实现 |
我的年度总结 |
【C语言】以深厚地基筑伟岸高楼-基础篇(六 |
c语言常见错误合集 |
|
上一篇文章 下一篇文章 查看所有文章 |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 | -2025/1/11 6:21:27- |
|
网站联系: qq:121756557 email:121756557@qq.com IT数码 |