C++STL算法之堆算法

简介: C++STL算法之堆算法

堆就是如图,像这样一种连续的数据,但是注意0的位置不存储数据,目的是为了让编号一置

这里介绍两个概念

大顶堆: 一段内存在二叉数的基础上有序(父节点大于子节点)

小顶堆:与顶堆相反

堆算法函数

make_heap 创建一个堆(默认形式大顶堆)

push_heap

入堆(不是传的数据,只是每一次调用,让你变成堆的形式),起到一个调整数据位置的作用

pop_heap 出堆,也只是一个调整数据,将数据放到堆后面

sort_heap堆排序

注意:真正意义上的,插入数据和删除数据,还是要根据相应的容器调用其中的函数(比如:push_back,pop_back)

堆算法函数的使用

make_heap

有三个参数,前2个参数表示迭代器的范围,最后一个参数写比较准则

#include<iostream>
#include<functional>
#include<algorithm>
#include<vector>
using namespace std;
int main()
{
  vector<int> v1 = { 1, 2, 9, 7, 9 };
  make_heap(v1.begin(), v1.end());//默认形式是大顶堆
  for_each(v1.begin(), v1.end(), [](int& date) {cout << date << " "; });
  cout << endl;
  make_heap(v1.begin(), v1.end(), less<int>()); //大顶堆
  copy(v1.begin(), v1.end(), ostream_iterator<int>(cout, " "));
  cout << endl;
  make_heap(v1.begin(), v1.end(), greater<int>());  //小顶堆
  copy(v1.begin(), v1.end(), ostream_iterator<int>(cout, " "));
  return 0;
}

push_heap

在插入数据的时候,调用这个函数,将其变为堆的形式

#include<iostream>
#include<functional>
#include<algorithm>
#include<vector>
using namespace std;
int main()
{
  vector<int> v1 = { 1, 2, 9, 7, 9 };
  make_heap(v1.begin(), v1.end());//默认形式是大顶堆
  for_each(v1.begin(), v1.end(), [](int& date) {cout << date << " "; });
  cout << endl;
  v1.push_back(8);
  v1.push_back(4);
  for_each(v1.begin(), v1.end(), [](int& date) {cout << date << " "; });
  cout << endl;
  push_heap(v1.begin(), v1.end());
  for_each(v1.begin(), v1.end(), [](int& date) {cout << date << " "; });
  return 0;
}

pop_heap

出堆的时候,先调用这个函数,将第一个元素,放到最后面,然后用尾删法,删除数据

#include<iostream>
#include<functional>
#include<algorithm>
#include<vector>
using namespace std;
int main()
{
  vector<int> v1 = { 1, 2, 9, 7, 9 };
  make_heap(v1.begin(), v1.end());//默认形式是大顶堆
  for_each(v1.begin(), v1.end(), [](int& date) {cout << date << " "; });
  cout << endl;
  pop_heap(v1.begin(), v1.end());  //堆的删除
  for_each(v1.begin(), v1.end(), [](int& date) {cout << date << " "; });
  cout << endl;
  v1.pop_back();
  for_each(v1.begin(), v1.end(), [](int& date) {cout << date << " "; });
  make_heap(v1.begin(), v1.end());
  cout << endl;
  for_each(v1.begin(), v1.end(), [](int& date) {cout << date << " "; });
  cout << endl;
  return 0;
}

sort_heap

这个排序默认,也就是简单的从小到大排序,当然第三个参数,你应该也可以写比较准则

#include<iostream>
#include<functional>
#include<algorithm>
#include<vector>
using namespace std;
int main()
{
  vector<int> v1 = { 1, 2, 9, 7, 9 };
  make_heap(v1.begin(), v1.end());//默认形式是大顶堆
  for_each(v1.begin(), v1.end(), [](int& date) {cout << date << " "; });
  cout << endl;
  sort_heap(v1.begin(), v1.end());
  for_each(v1.begin(), v1.end(), [](int& date) {cout << date << " "; });
  return 0;
}



相关文章
|
22天前
|
缓存 算法 Java
JVM知识体系学习六:JVM垃圾是什么、GC常用垃圾清除算法、堆内存逻辑分区、栈上分配、对象何时进入老年代、有关老年代新生代的两个问题、常见的垃圾回收器、CMS
这篇文章详细介绍了Java虚拟机(JVM)中的垃圾回收机制,包括垃圾的定义、垃圾回收算法、堆内存的逻辑分区、对象的内存分配和回收过程,以及不同垃圾回收器的工作原理和参数设置。
45 4
JVM知识体系学习六:JVM垃圾是什么、GC常用垃圾清除算法、堆内存逻辑分区、栈上分配、对象何时进入老年代、有关老年代新生代的两个问题、常见的垃圾回收器、CMS
|
20天前
|
存储 程序员 C++
C++常用基础知识—STL库(2)
C++常用基础知识—STL库(2)
60 5
|
20天前
|
存储 自然语言处理 程序员
C++常用基础知识—STL库(1)
C++常用基础知识—STL库(1)
44 1
|
25天前
|
存储 算法 C++
高精度算法(加、减、乘、除,使用c++实现)
高精度算法(加、减、乘、除,使用c++实现)
295 0
高精度算法(加、减、乘、除,使用c++实现)
|
29天前
|
算法 安全 Linux
【C++STL简介】——我与C++的不解之缘(八)
【C++STL简介】——我与C++的不解之缘(八)
|
22天前
|
算法 数据处理 C++
c++ STL划分算法;partition()、partition_copy()、stable_partition()、partition_point()详解
这些算法是C++ STL中处理和组织数据的强大工具,能够高效地实现复杂的数据处理逻辑。理解它们的差异和应用场景,将有助于编写更加高效和清晰的C++代码。
16 0
|
1月前
|
存储 算法 决策智能
【算法】博弈论(C/C++)
【算法】博弈论(C/C++)
|
1月前
|
存储 算法 C++
【算法】哈希映射(C/C++)
【算法】哈希映射(C/C++)
|
12天前
|
算法 安全 数据安全/隐私保护
基于game-based算法的动态频谱访问matlab仿真
本算法展示了在认知无线电网络中,通过游戏理论优化动态频谱访问,提高频谱利用率和物理层安全性。程序运行效果包括负载因子、传输功率、信噪比对用户效用和保密率的影响分析。软件版本:Matlab 2022a。完整代码包含详细中文注释和操作视频。
|
10天前
|
人工智能 算法 数据安全/隐私保护
基于遗传优化的SVD水印嵌入提取算法matlab仿真
该算法基于遗传优化的SVD水印嵌入与提取技术,通过遗传算法优化水印嵌入参数,提高水印的鲁棒性和隐蔽性。在MATLAB2022a环境下测试,展示了优化前后的性能对比及不同干扰下的水印提取效果。核心程序实现了SVD分解、遗传算法流程及其参数优化,有效提升了水印技术的应用价值。