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

西安高新区网站建设dw 怎么做钓鱼网站

西安高新区网站建设,dw 怎么做钓鱼网站,傻瓜化免费自助建站,网站做接口需要哪些C初学者指南-5.标准库(第二部分)–二叉堆操作 文章目录 C初学者指南-5.标准库(第二部分)--二叉堆操作背景什么是“堆”二叉最大堆二叉树的表示 堆操作C标准库中的堆初始化堆收缩堆增长堆 辅助操作sort_heap (Heap → Sorted Array)is_heapis_heap_until 相关内容 不熟悉 C 的标…

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++ 之旅:容器和算法
算法概述表:
在这里插入图片描述

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

http://www.yayakq.cn/news/761780/

相关文章:

  • 免费推广做产品的网站江阴做网站的公司
  • 禾天姿网站建设网站建设流程的怎样的
  • 怎么填写网站icp备案做防水网站
  • 友情链接交易网站中国建设教育协会官网证书查询
  • 1个ip可以做几个网站免费主机服务器
  • 天津企业设计网站建设珠宝 东莞网站建设
  • 建立学校网站需要多少钱?做海报那个网站好
  • 免费建站免费网站申请汕头市专注网站建设
  • 杭州最大的网站开发用什么软件建网站最方便
  • 建设景区网站推文五站合一自建网站
  • 网站建设开票专业的郑州网站推广
  • 网站优化方案基本流程什么是电子商务系统
  • 哪个网站可以做危险化学品供求网站建设选哪家公司好
  • 网站流量统计数据库设计网页前端设计的心得体会
  • 昆山专业网站建设公司哪家好河源市建设厅网站
  • 福州市工程建设质量管理协会网站搭建个网站多少钱
  • 游戏网站开发计划书北京管理咨询公司
  • 上海企业网站seo国内商城网站建设
  • 自己做网站编程wordpress加入博客
  • 深圳腾网站建设深圳均安网站制作
  • 如何做网站推广私人wordpress wordapp插件
  • 制作网站的方法一个网站开发成本
  • 网站建设合同规定一级a做爰片免费网站给我看看
  • 静态网站开发课程相关新闻seo优化方案模板
  • 手机网站建设专业服务公司西安网站建设网站
  • 苏州网站建设店铺装修网站退出率
  • 网站栏目及内容wordpress压缩插件
  • 网站制作方案答案是螃蟹的迷语企业网站建设的策略
  • 做网站的不肯给ftp百度网站建设目标
  • 可视化手机网站开发工具网站工作和网站建设管理工作