heap 堆

本文介绍了一种使用C++标准库实现堆的操作方法,包括建堆、插入元素、弹出堆顶元素等步骤,并通过示例代码展示了如何创建大堆和小堆。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

不用自己写堆啦,懒人必备,比如我。

整理了操作:

#include<bits/stdc++.h>
#define il inline
#define pb push_back
#define fi first
#define se second
#define ms(_data,v) memset(_data,v,sizeof(_data))
using namespace std;
typedef long long ll;
const ll inf=0x3f3f3f3f;
bool cmp(int x,int y){return x>y;}	//小堆 或者用 greater<int>()
bool CMP(int x,int y){return x<y;}	//大堆 

int main(){
	std::ios::sync_with_stdio(0);
	int a[]={1,2,-199,122,88};
	vector<int> mx(a,a+5),mi(a,a+5);
	//建堆 
	make_heap(mx.begin(),mx.end());//默认大堆
	make_heap(mi.begin(),mi.end(),cmp);//小堆 
	
	//输出堆顶
	cout<<mx.front()<<" "<<mi.front()<<endl;
	
	//插入元素 
	mx.pb(77),push_heap(mx.begin(),mx.end());
	mi.pb(77),push_heap(mi.begin(),mi.end(),cmp); //更新也要cmp哦
	
	//弹出堆顶元素
	pop_heap(mx.begin(),mx.end()),mx.pop_back(); 
	pop_heap(mi.begin(),mi.end(),cmp),mi.pop_back(); //也要加 
	
	return 0;
}

还想多多了解

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值