priority_queue与multiset
感觉c++最有用的stl是bitset、堆(优先队列)和平衡树,其他的都可以手打
这里主要讲一下堆和平衡树的基本用法和区别所在
priority_queue
堆/优先队列
定义:
priority_queue<类型>
priority_queue<int> 大根堆
priority_queue<int,vector<int>,less<int> > 大根堆
priority_queue<int,vector<int>,greater<int> > 小根堆
priority_queue<结构体>
基本函数:
push(x):加入一个元素,可以是数or结构体
pop():弹出堆顶
top():堆顶的元素
size():堆的大小
empty():是否为空(空即为1)
关于结构体的比较:
struct type{
int x,y;
bool friend operator < (type a,type b) {return a.x<b.x;}
//反正这样写就对了
};
结构体的赋值可以为{a,b,...}或 名称{a,b,...}
multiset
与set的不同在于multiset可以有重复元素,所以一般都用multiset
定义:
multiset<类型>
multiset<int> 从小到大
multiset<int,less<int> > 从小到大
multiset<int,greater<int> > 从大到小
multiset<结构体>
迭代器:
multiset<定义和对应的set一致> ::iterator
作用是遍历set/特别指向某一个元素
基本函数:
insert(x):加入一个元素,可以是数/结构体
erase(x):
有两种情况
①x是数/结构体
那么会把所有的x删掉
②x是某一个迭代器
那么只会删掉迭代器对应的元素
begin():返回关键值最小的元素指针
(指针x对应的值为*x,如果是结构体则为(*x).a)
end():返回关键值最大的元素指针的后一位(最大的是--end())
size()、empty():同优先队列
lower_bound(x):第一个大于等于x的元素指针
upper_bound(x):第一个大于x的元素指针
小于等于=大于 的前一位,小于=大于等于 的前一位
e.insert(1);e.insert(2);e.insert(3);e.insert(4);e.insert(5);
cout<<*e.lower_bound(3)<<" "<<*e.upper_bound(3)<<endl; //>= >
cout<<*--e.lower_bound(3)<<" "<<*--e.upper_bound(3)<<endl; //< <=
//3 4
//2 3
遍历:
可以通过迭代器的移动来遍历
(头为begin(),尾为--end(),最大能走到end())
e.insert(1);e.insert(2);e.insert(3);
I=e.begin();
while (I!=e.end())
cout<<*I<<" ",*++I;
cout<<endl;
//1 2 3
区别
multiset可以遍历/找前驱后继/删除
*重点:priority_queue的比较机制和set/sort相反
#include <algorithm>
#include <iostream>
#include <cstdlib>
#include <cstring>
#include <cstdio>
#include <queue>
#include <set>
#define fo(a,b,c) for (a=b; a<=c; a++)
#define fd(a,b,c) for (a=b; a>=c; a--)
using namespace std;
struct type{
int x,y;
bool friend operator < (type a,type b) {return a.x<b.x;}
};
multiset<type> a;
priority_queue<type> b;
type c[3];
int main()
{
a.insert({3,3});a.insert({2,2});a.insert({1,1});
b.push({1,1});b.push({2,2});b.push({3,3});
c[0]={3,3};c[1]={2,2};c[2]={1,1};
sort(c,c+3);
cout<<(*a.begin()).x<<" "<<b.top().x<<" "<<c[0].x<<endl;
//1 3 1
}
可以发现,优先队列得到的结果和multiset/sort刚好相反
实际上,multiset/sort最终的状态满足a1<a2<a3...<an(<可以是定义的运算)
而priority_queue应该是当一个元素x满足fa[x]<x时交换,实质上维护的是大根堆
一种记忆方法:"优先"队列=先大后小
priority_queue与multiset的更多相关文章
- POJ 2431 Expedition (priority_queue或者multiset可解)
Expedition Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 18655 Accepted: 5405 Descr ...
- [CareerCup] 11.8 The Rank of Number 数的排行
11.8 Imagine you are reading in a stream of integers. Periodically, you wish to be able to look up t ...
- CSP-S 2019提高组训练 服务器需求
时间限制:C/C++ 3秒 空间限制:C/C++ 262144K 题目描述 小多计划在接下来的n天里租用一些服务器,所有的服务器都是相同的.接下来n天中,第i天需要\(a_i\)台服务器工作,每台服务 ...
- STL容器(Stack, Queue, List, Vector, Deque, Priority_Queue, Map, Pair, Set, Multiset, Multimap)
一.Stack(栈) 这个没啥好说的,就是后进先出的一个容器. 基本操作有: stack<int>q; q.push(); //入栈 q.pop(); //出栈 q.top(); //返回 ...
- HDU 4006 The kth great number(multiset(或者)优先队列)
题目 询问第K大的数 //这是我最初的想法,用multiset,AC了——好吧,也许是数据弱也有可能 //multiset运用——不去重,边插入边排序 //iterator的运用,插入的时候,如果是相 ...
- STL 整理(map、set、vector、list、stack、queue、deque、priority_queue)(转)
向量(vector) <vector> 连续存储的元素<vector> Vector<int>c; c.back() 传回最后一个数据,不检查这个数据是否存在 ...
- nyoj 55 懒省事的小明 优先队列 multiset 还有暴力
懒省事的小明 时间限制: 3000 ms | 内存限制: 65535 KB 难度: 3 描述 小明很想吃果子,正好果园果子熟了.在果园里,小明已经将所有的果子打了下来,而且按果子的 ...
- multimap 和priority_queue详解
上一期是关于STL和并查集结合的例题,也附了STL中部分容器的使用摘要,由于是从网上东拼西凑的,感觉有的关键点还是没解释清楚,现在从其中摘出两个容器,用例题对它们的用法进行进一步解释. 以下是例题的介 ...
- HDU 4268 multiset
http://acm.hust.edu.cn/vjudge/contest/123100#problem/B #include <iostream> #include <string ...
随机推荐
- LeetCode.1046-最后的石头重量(Last Stone Weight)
这是小川的第388次更新,第418篇原创 01 看题和准备 今天介绍的是LeetCode算法题中Easy级别的第250题(顺位题号是1046).有一个石头集合,每个石头都有一个正整数重量值. 每次,我 ...
- DNS的解析流程
一.简单理解 DNS服务器里存着一张表,表中放着域名和IP地址,域名和IP地址以映射关系保存,即一对一 浏览器访问某个域名,实际上是访问它的ip地址 所以浏览器需要知道域名对应的ip地址,由此产生dn ...
- USACO3.3 A Game【区间dp】
这道题也是一道非常有意思的区间$dp$,和在纪中的这道题有点像:取数游戏 (除了取数规则其它好像都一样诶) 当时在纪中的时候就觉得这个$dp$非常不好想,状态定义都不是很容易想到. 但是做过一道这种题 ...
- mongodb 数据库操作 -- 》常用命令
首先需要下载数据库,安装后,找到bin目录,点开bin目录,复制当前路径配置到环境变量中 和bin的同级下,需要建立一个data/db文件夹,该文件夹并不会自动生成,必须手动设置 启动数据库 看 ...
- Excel透视表进阶之排序、筛选、分组、总计与分类汇总
排序 自动排序 升序: 数字(从小到大) 日期(日期越早越靠小) 英文(按照A-Z) 中文(按照拼音的A-Z) 手动排序 通过鼠标的拖拽来完成手动排序 通过快捷菜单的方式:右击-移动 依据其他字段进行 ...
- [TJOI2019] 甲苯先生的线段树
臭名昭著的巧合:CF750G 题意:在无限深度的一颗线段树中询问编号和为S的简单路径条数. 题解传送门 这道题相当于在原来基础上多了询问两点间简单路径的编号的的问题. 直觉告诉我们只需要求出两点在线段 ...
- 运维LVS三种模式十种调度算法
一.LVS简介 LVS(Linux Virtual Server)即Linux虚拟服务器,是由章文嵩博士主导的开源负载均衡项目,目前LVS已经被集成到Linux内核模块中.该项目在Linux内核中实现 ...
- wex5 如何写后台BAAS
Data.java: 在class中链接数据源: 配置的numsql数据源 private static final String DATASOURCE_NUMYSQL = "numysql ...
- spring-cloud学习BUG
1.com.sun.jersey.api.client.ClientHandlerException: java.net.ConnectException: Connection refused: c ...
- App原生、混合、纯WEB开发模式的优劣分析
什么叫做原生App? 什么是混合app? 什么是Web App开发? Native App开发即我们所称的传统APP开发模式(原生APP开发模式),该开发针对IOS.Android等不同的手机操作系统 ...