今年暑假外校集训的时候一道题标算是最短路扩展,然而std用的是pbds,于是就产生了研究的兴趣。结果那个标程我现在死都找不到了233

定义:

在知乎上看到有oier去年向CCF发了邮件,得到的回复是pbds库可以用,但是不能写这句话:

using namespace __gnu_pbds;

存图为证。

--------------------------------------------------------------------------原答案分割线--------------------------------------------------------------------------------------------------------------------------------------

pbds是一个封装了众多高效又实用(相对于STL)的数据结构的库,包括堆,平衡树,哈希表等。然而目前仍然不清楚NOIP中能否使用。在CCF2011年发布的关于NOI系列赛编程语言使用限制的规定中明确规定C/C++程序禁止使用内嵌汇编和以下划线开头的库函数或宏(自己定义的除外),然而在WC2015营员交流中一位同学却说pbds在NOI系列赛事中可以使用,这就造成了现在的这种尴尬境地。

由于本人实在蒟蒻,加上pbds的平衡树在维护有序序列时对存在重复元素的情况维护难度较大,且该问题用STL中的vector就可以妥善解决,(之前自己智障),在此只介绍pbds中堆的用法。

用法:

由于bits/stdc++.h不覆盖pbds,使用时需加上#include<ext/pb_ds/priority_queue.hpp>和using namespace __gnu_pbds;(gnu前两条下划线)。(命名空间不能使用)

注意:pbds的堆在定义时不需要vector<int>。

定义一个int类型的小根堆:__gnu_pbds::priority_queue<int,greater<int>,TAG>pq;

TAG指明了所用堆的类型,共有以下几种:

pairing_heap_tag:配对堆

thin_heap_tag:斐波那契堆

binomial_heap_tag:二项堆

binary_heap_tag:二叉堆

如果是大根堆的话只需要去掉greater<int>即可,也可以定义结构体类型或者其他类型,只要重载了<运算符就可以使用。

这些堆普遍支持push,pop,top和join操作。最后一个操作是将两个堆合并,使用方法:a.join(b);//将堆b合并至堆a中

配对堆和斐波那契堆的理论复杂度均十分优异,push,top,join都能做到均摊O(1),pop能做到O(logn)。

二项堆的各种操作复杂度都是O(logn)。二叉堆的复杂度不知,但实际运行速度极慢,反而不如std和手写堆,不知是何原因,不建议使用。

拿一道最短路例题来测试一下各种堆的速度吧:

例题:

Luogu P3371 【模板】单源最短路径 题目链接

题意:给定一张n个点,m条边的有向图和起点s,要求输出s到每个点的最短距离,若不可达输出2147483647。

数据范围:n<=10000,m<=500000。

题解:SPFA或dijkstra堆优化。

配对堆:756ms

斐波那契堆:664ms

二项堆:812ms

二叉堆:1516ms+3TLE

TAG留空(我也不知道这是什么骚操作):586ms

基本符合理论复杂度。在平时或者考场上时建议使用配对堆或斐波那契堆或者直接留空。

最新文章

  1. 【转】oracle中in和exists的区别
  2. Beta版本——第五次冲刺博客
  3. 检测电脑安装的net framework版本
  4. OOD、OOP、AOP区别
  5. Microsoft Office 2010 Pro VOL简体中文正式版
  6. 从零开始学习jQuery(剧场版) 你必须知道的javascript
  7. 线段树入门HDU_1754
  8. [再寄小读者之数学篇](2014-06-22 不等式 [中国科学技术大学2011年高等数学B考研试题])
  9. [LeetCode] Design Circular Queue 设计环形队列
  10. C#语言のC#扩展方法(.Net特性)
  11. Spring Boot 启动:No active profile set, falling back to default profiles: default
  12. python基础学习第三天
  13. Java: |(或运算) 与 多选判断
  14. CentOS下设置vim的tab键为4格
  15. VSTO:C#获取文档控件的值
  16. maven根据不同的运行环境,打包不同的配置文件
  17. pop3_用Java发送图文并茂的HTML邮件
  18. ios8 xcode6 下的启动界面设置和图标设置
  19. Activiti 数据库表自动生成策略
  20. Python3网络爬虫:urllib.error异常

热门文章

  1. Manjaro Linux 5.9.11-3安装和配置全局截图工具FlameShot教程
  2. 【Oracle】创建用户配额总是不足的解决问题 quota
  3. 爬虫-使用lxml解析html数据
  4. 为什么会有 AtomicReference ?
  5. OpenCV 和 Dlib 人脸识别基础
  6. Flask的配置文件加载两种方式
  7. 将汉字取模软件中的汉字放到keil5中显示
  8. k8s之PV、PVC、StorageClass详解
  9. Soul API 网关源码解析 03
  10. MySQL中redo log、undo log、binlog关系以及区别