当前位置: 首页 > news >正文

C++初学者指南-5.标准库(第二部分)--二叉堆操作

C++初学者指南-5.标准库(第二部分)–二叉堆操作

文章目录

  • C++初学者指南-5.标准库(第二部分)--二叉堆操作
    • 背景
      • 什么是“堆”
      • 二叉最大堆
      • 二叉树的表示
    • 堆操作
      • C++标准库中的堆
      • 初始化堆
      • 收缩堆
      • 增长堆
    • 辅助操作
      • sort_heap (Heap → Sorted Array)
      • is_heap
      • is_heap_until
    • 相关内容

不熟悉 C++ 的标准库算法? ⇒ 简介

背景

什么是“堆”

  • 一组数据结构(不要和动态存储的内存分区搞混)
  • 它们包含可以排序的对象(键)
  • 它们根据排序被称为“最大堆”或“最小堆”
  • 它们通常用于实现优先队列

支持的操作通常包括:

通常在 O(1)(常数时间)内获取最大值
通常在 O(log N)(对数时间)内移除最大值
通常在 O(1) 或 O(log N) 的时间内插入新键
通常在 O(1) 或 O(log N) 的时间内增加/减少键的变化值

维基百科:“堆”数据结构

二叉最大堆

  • 键存储在二叉树的节点中
  • 键必须是可排序的,即可比较的。
  • 堆属性:父节点的所有子节点的键必须小于或等于父节点的键 P ⇒ 根节点具有最大值
    在这里插入图片描述
    操作的时间复杂度:
  • 获取最大值:O(1)(恒定时间)
  • 删除最大值:O(log N)(对数时间)
  • 插入:O(log N)
  • 增加键:O(log N)

二叉树的表示

几乎所有的完全二叉树都可以用数组来表示。

  • 树要么由一个节点组成,要么在所有内部层级上必须是完整的。
  • 可能没有最右边的叶节点。
    在这里插入图片描述
    在这里插入图片描述

堆操作

C++标准库中的堆

  • 二叉最大堆
  • 由一个类似数组的容器表示
  • 最大值 = 树根 = 数组中的第一个元素
  • 键必须可排序(默认使用运算符 <)
    在这里插入图片描述

堆操作 = 是重排(迭代器)范围内元素的算法

  • make_heap:将一串键值重新排序成二叉堆
  • push_heap:插入新键
  • pop_heap:删除最大值

注意:如果你只想要一个优先队列,可以使用专门的标准容器类型 std::priority_queue。

初始化堆

在这里插入图片描述
cppreference

std::vector<int> h {1,6,4,2,9,7,8};
// make max heap (default)
make_heap(begin(h), end(h));
for (int x : h) { cout << x << ' '; }  // 9 6 8 2 1 7 4
// make min heap
make_heap(begin(h), end(h), std::greater<>{});
for (int x : h) { cout << x << ' '; }  // 1 2 4 9 6 7 8

运行示例代码
在这里插入图片描述
cppreference

收缩堆

在这里插入图片描述
cppreference

std::vector<int> h {1,2,4,9,8,7,6};
make_heap(begin(h), end(h));  // 9 6 8 2 1 4 7
// remove element from heap:
pop_heap(begin(h), end(h));
auto oldmax = h.back();  // oldmax = 9
h.pop_back();
for (int x : h) { cout << x << ' '; }  // 8 6 7 2 1 4

运行示例代码
在这里插入图片描述
cppreference

示例:连续收缩
在这里插入图片描述

增长堆

在这里插入图片描述
cppreference

std::vector<int> h {1,2,4,8,6,7};
make_heap(begin(h), end(h));  // 8 6 7 2 1 4
// add new element to heap:
h.push_back(9);
push_heap(begin(h), end(h));
for (int x : h) { cout << x << ' '; }  // 9 6 8 2 1 4 7

运行示例代码
在这里插入图片描述
cppreference

示例:不断增长
在这里插入图片描述

辅助操作

sort_heap (Heap → Sorted Array)

在这里插入图片描述
cppreference
在这里插入图片描述
cppreference

is_heap

在这里插入图片描述
cppreference
在这里插入图片描述
cppreference

is_heap_until

在这里插入图片描述
cppreference
在这里插入图片描述
cppreference

相关内容

“堆”数据结构
标准算法概述
C++标准库算法介绍
标准序列容器(vector、deque、list、…)
标准关联容器(map、set、…)
标准序列视图
cppreference:算法库
cppreference:容器库
视频:什么是 C++ 标准库?
视频:一小时内掌握 105 个 STL 算法 (Jonathan Boccara,2018)
C++ 之旅:容器和算法
算法概述表:
在这里插入图片描述

附上原文链接
如果文章对您有用,请随手点个赞,谢谢!^_^

相关文章:

C++初学者指南-5.标准库(第二部分)--二叉堆操作

C初学者指南-5.标准库(第二部分)–二叉堆操作 文章目录 C初学者指南-5.标准库(第二部分)--二叉堆操作背景什么是“堆”二叉最大堆二叉树的表示 堆操作C标准库中的堆初始化堆收缩堆增长堆 辅助操作sort_heap (Heap → Sorted Array)is_heapis_heap_until 相关内容 不熟悉 C 的标…...

在Ubuntu 16.04上安装Git的方法

前些天发现了一个巨牛的人工智能学习网站&#xff0c;通俗易懂&#xff0c;风趣幽默&#xff0c;忍不住分享一下给大家。点击跳转到网站。 简介 在现代软件开发中&#xff0c;一个不可或缺的工具是某种版本控制系统。版本控制系统允许您在源代码级别跟踪软件。您可以跟踪更改…...

redis内存淘汰策略-------Reservoir Sampling(水库采样)

文章目录 过期删除策略和内存淘汰策略内存淘汰策略evictionPoolEntryevictionPoolPopulate Reservoir SamplingdictGetRandomKeydictGetSomeKeysReservoir Samplingchatgpt对Reservoir Sampling的介绍 过期删除策略和内存淘汰策略 详细介绍请参考博客“redis过期删除策略和内存…...

C++《类和对象》(上)

在之前的C入门基础知识中我们了解了C的发展过程已经重要性&#xff0c;还初步了解了C中一些相比C语言特有的知识点&#xff0c;例如命名空间、缺少参数、函数重载、引用等&#xff0c;接下来在本篇中我们将开始C整个体系中非常重要的一个知识章节——类和对象&#xff0c;类和对…...

LLM大语言模型算法特训

百度 LLM&#xff08;Large Language Model&#xff09;大语言模型算法特训是一个深度学习领域的高级培训项目&#xff0c;专门设计用于训练和优化大规模语言模型的开发者和研究人员。本文将详细探讨LLM算法的基本原理、训练技术、应用领域以及参与者可以预期的学习收获和挑战。…...

Docker相关笔记

Docker笔记 1. Dockerfile编译构建docker Dockerfile 是一个文本文件&#xff0c;包含了构建 Docker 镜像的所有指令。 Dockerfile 常用的有如下关键字&#xff1a; FROM&#xff1a;指定基础镜像&#xff0c;后续定制操作都是基于这个基础镜像&#xff0c;比如&#xff1a; …...

前端技术day01-HTML入门

一、前端介绍 技术描述HTML用于构建网站的基础结构的CSS用于美化页面的&#xff0c;作用和化妆或者整容作用一样JS实现网页和用户的交互Vue主要用于将数据填充到html页面上的Element主要提供了一些非常美观的组件 二、工具软件 VsCode 在前端领域&#xff0c;有一个公认好用…...

Multisim 用LM358 运放模拟线性稳压器 - 运放输出饱和 - 前馈电容

就是拿运放搭一个可调的LDO 稳压器&#xff0c;类似下面这个功能框图里的感觉。本来应该非常简单&#xff0c;没什么好说的&#xff0c;没想到遇到了两个问题。 原理 - 理想运放 我用PNP 三极管Q2 作为输出&#xff0c;运放输出电压升高时&#xff0c;流过PNP 三极管BE 的电流变…...

宁德大屏第二版总结

碰到难点 1.wss 心跳机制 实现前端和后端双向绑定 只要后端发送了消息 前端通过全局总线去触发你想要的函数。 全局总线 vue3可以全局总线下一个mitt 新建一个eventBus.js import mitt from "mitt"; const eventBus mitt();export default eventBus; 然后wss…...

冥想第一千二百四十七天(1247)

1.今天上午带桐桐去游泳了&#xff0c;买了卡吉诺&#xff0c;吃过最好吃的甜点。推荐。还有鸡排。 2.回来后带着媳妇&#xff0c;先加油。去给丈母娘看腿&#xff0c;等丈母娘等了好久&#xff0c;还帮她推车。 3.回来后&#xff0c;在丈母娘家跑步。很舒服。家长麦田的香味。…...

基于光学动捕定位下的Unity-VR手柄交互

Unity VR 场景手柄交互实现方案 需求 在已创建好的 Unity VR 场景中&#xff0c;接入游戏手柄&#xff0c;通过结合动捕系统与 VRPN&#xff0c;建立刚体&#xff0c;实时系统获取到手柄的定位数据与按键数据&#xff0c;通过编写代码实现手柄的交互逻辑&#xff0c;实现手柄…...

php json_decode 带反斜杠字符串json解析

PHP json_decode 带反斜杠字符串json解析 今天再次遇到了json字符串中包含反斜杠的问题&#xff0c;记录下解决方法 在JSON字符串中&#xff0c;反斜杠\用作转义字符。当JSON_UNESCAPED_SLASHES选项被用于json_encode()函数时&#xff0c;不会在slashes前面添加反斜杠。 但是…...

【NLP】文本张量表示方法【word2vec、词嵌入】

文章目录 1、文本张量表示2、one-hot词向量表示2.1、one-hot编码代码实现&#xff1a;2.2、onehot编码器的使用2.3、one-hot编码的优劣势 3、word2vec模型3.1、模型介绍3.2、CBOW模式3.3、skipgram模式3.4、word2vec的训练和使用3.4.1、获取训练数据3.4.2、训练词向量3.4.3、查…...

疯狂Java讲义_08_泛型

文章目录 泛型的传参若函数里的参数使用基类接受所有的派生类&#xff0c;怎么做&#xff1f; 类型通配符的上限类型通配符的下限 泛型的传参 注意 若类 Base 是类 Derived 的基类&#xff08;父类&#xff09;&#xff0c;那么数组类型 Base[] 是 Derived[] 的基类&#xff0…...

HCIA、OSPF笔记

一、OSI参考模型 1、OSI的结构 应用层&#xff1a;把人类语言转化成编码&#xff0c;为各种应用程序提供网络服务。 表示层&#xff1a;定义一些数据的格式&#xff0c;&#xff08;对数据进行加密、解密、编码、解码、压缩、解压缩&#xff0c;每一层都可以实现&#xff0c…...

Python删除lru_cache缓存

在 Python 中,lru_cache 是一个装饰器,用于添加缓存功能以提高函数的性能。如果你想清除或者删除 lru_cache 中的缓存,有几种方法可以做到: 手动清除缓存: lru_cache 对象有一个方法叫做 cache_clear(),可以手动清除所有缓存。示例:@lru_cache(maxsize=128) def some_fun…...

Android面试必问题:大白文讲透Android View工作原理

目录 第一章 引言 第二章 Android View 基础概念 2.1 视图(View) 2.2 布局(Layout) 2.3 绘制(Drawing) 第三章 Android View 工作原理详解 3.1 测量过程剖析 3.2 布局流程探究 第四章 Android View 性能优化建议 4.1 视图层级优化 4.2 避免过度的视觉效果 4.…...

WinDbg配置远程调试

WinDbg配置远程调试 1、为什么需要远程调试 某些特殊的场合需要远程调试&#xff0c;如&#xff1a; ①调试特殊的程序&#xff0c;比如在调试全屏程序&#xff0c;内核。 ②需要别人帮助调试或者帮助别人调试。比如由于商业性质不能直接给你pdb和源代码。 ③还有一类就是…...

spl注入实战thinkphp

目录 一、环境的部署 二、本地创建数据库 三、填写数据库连接文件 四、编写控制器 五、访问分析 debug报错会显示物理路径 原因是config.php文件相关配置 六、注入分析 七、进入断点调试 八、通过mysql执行语句查看结果 九、总结&#xff1a; 一、环境的部署 二、本地…...

整理深度学习时最常用的Linux命令(自用)

清华大学镜像源&#xff1a; https://pypi.tuna.tsinghua.edu.cn/simple/tar文件解压 tar -xzvf xxx.tar.gztar xvf xxx.tarzip文件解压 unzip xxx.zip -d path/to/your/fold清理GPU异常内存占用 杀掉 1 号显卡的所有进程 fuser -v /dev/nvidia1 | xargs -t -n 1 kill -9杀掉…...

Beyond Compare 5 许可证书生成与应用完全指南

Beyond Compare 5 许可证书生成与应用完全指南 【免费下载链接】BCompare_Keygen Keygen for BCompare 5 项目地址: https://gitcode.com/gh_mirrors/bc/BCompare_Keygen 一、问题剖析&#xff1a;许可管理核心挑战 1.1 评估期限制的实际影响 Beyond Compare 5作为专业…...

vue3 父组件向子组件传参

vue3中父组件向子组件传递参数&#xff0c;核心方案是&#xff1a;父组件用 v-bind 绑定数据&#xff0c;子组件用 defineProps 接收数据&#xff08;组合式 API 语法&#xff09;。即&#xff1a;v-bind 传 &#xff08;父&#xff09; defineProps 收&#xff08;子&#xff…...

工业级模拟量采集模块:空气温湿度采集,大棚环境全自动

模拟量采集模块在智慧农业中扮演着“神经末梢”的角色&#xff0c;负责将土壤/水体的温湿度、EC/pH、溶氧、光照等连续物理量转化为数字信号&#xff0c;为精准灌溉、水肥一体、水质调控提供可靠数据入口&#xff0c;直接决定生产决策的准确性与效率。一、系统架构感知层&#…...

C#的[DoesNotReturn]和[DoesNotReturnIf]:帮助流分析的特性

C#的[DoesNotReturn]和[DoesNotReturnIf]特性是编译器流分析的重要工具&#xff0c;它们通过显式标记方法或代码块的终止行为&#xff0c;帮助开发者编写更安全、更高效的代码。这些特性在异常处理、条件终止等场景中尤为实用&#xff0c;能够显著提升代码的可读性和静态分析的…...

FasterRCNN训练完别急着关!用predict.py批量预测并保存结果的完整配置指南

FasterRCNN模型预测实战&#xff1a;从批量推理到结果保存的全流程解析 当你终于完成FasterRCNN模型漫长的训练过程&#xff0c;看着损失曲线平稳下降&#xff0c;验证集指标达到预期&#xff0c;那种成就感不言而喻。但很多开发者在这里犯了一个常见错误——直接关闭项目转向下…...

从Stuxnet到S7CommPlus:一个C#程序员的工控协议安全入门笔记

从Stuxnet到S7CommPlus&#xff1a;一个C#程序员的工控协议安全入门笔记 工业控制系统&#xff08;ICS&#xff09;安全一直是个神秘而重要的领域。作为一名C#开发者&#xff0c;我曾以为这离我的日常开发很远&#xff0c;直到偶然接触到Stuxnet病毒的故事——这个专门针对西门…...

掌握Vue 3日历组件实战:从业务场景到深度定制的全流程指南

掌握Vue 3日历组件实战&#xff1a;从业务场景到深度定制的全流程指南 【免费下载链接】fullcalendar-vue The official Vue 3 component for FullCalendar 项目地址: https://gitcode.com/gh_mirrors/fu/fullcalendar-vue 在现代Web应用开发中&#xff0c;Vue 3日历组件…...

ProgrammingFonts网站功能详解:快速搜索、对比和评分系统

ProgrammingFonts网站功能详解&#xff1a;快速搜索、对比和评分系统 【免费下载链接】ProgrammingFonts This is a collection of programming fonts, just share this with the programmers. Now there are 108 kinds of fantastic fonts! 项目地址: https://gitcode.com/g…...

别再手动配环境了!用vcpkg在Windows上无痛安装osgEarth 3.7(附VS2019+避坑指南)

现代C开发者的效率革命&#xff1a;vcpkg一键部署osgEarth全攻略 在三维地理信息系统(GIS)和可视化领域&#xff0c;osgEarth作为开源地理空间工具包一直备受开发者青睐。然而&#xff0c;其复杂的依赖链和繁琐的编译过程常常让开发者望而却步——从OpenSceneGraph(OSG)基础库到…...

思欣跃:全面解析学习困难解决方案与情绪管理策略

学习困难的有效解决方案&#xff1a;全面分析和实践策略 在面对学习困难时&#xff0c;家长和教师可以采用多种具体的解决方案。首先&#xff0c;对于注意力不集中的问题&#xff0c;可以通过制定明确的学习目标和时间表来帮助学生集中精力。在课堂上&#xff0c;教师可以运用多…...