今年暑假外校集训的时候一道题标算是最短路扩展,然而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

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

pbds初探的更多相关文章

  1. 初探领域驱动设计(2)Repository在DDD中的应用

    概述 上一篇我们算是粗略的介绍了一下DDD,我们提到了实体.值类型和领域服务,也稍微讲到了DDD中的分层结构.但这只能算是一个很简单的介绍,并且我们在上篇的末尾还留下了一些问题,其中大家讨论比较多的, ...

  2. CSharpGL(8)使用3D纹理渲染体数据 (Volume Rendering) 初探

    CSharpGL(8)使用3D纹理渲染体数据 (Volume Rendering) 初探 2016-08-13 由于CSharpGL一直在更新,现在这个教程已经不适用最新的代码了.CSharpGL源码 ...

  3. 从273二手车的M站点初探js模块化编程

    前言 这几天在看273M站点时被他们的页面交互方式所吸引,他们的首页是采用三次加载+分页的方式.也就说分为大分页和小分页两种交互.大分页就是通过分页按钮来操作,小分页是通过下拉(向下滑动)时异步加载数 ...

  4. JavaScript学习(一) —— 环境搭建与JavaScript初探

    1.开发环境搭建 本系列教程的开发工具,我们采用HBuilder. 可以去网上下载最新的版本,然后解压一下就能直接用了.学习JavaScript,环境搭建是非常简单的,或者说,只要你有一个浏览器,一个 ...

  5. .NET文件并发与RabbitMQ(初探RabbitMQ)

    本文版权归博客园和作者吴双本人共同所有.欢迎转载,转载和爬虫请注明原文地址:http://www.cnblogs.com/tdws/p/5860668.html 想必MQ这两个字母对于各位前辈们和老司 ...

  6. React Native初探

    前言 很久之前就想研究React Native了,但是一直没有落地的机会,我一直认为一个技术要有落地的场景才有研究的意义,刚好最近迎来了新的APP,在可控的范围内,我们可以在上面做任何想做的事情. P ...

  7. 【手把手教你全文检索】Apache Lucene初探

    PS: 苦学一周全文检索,由原来的搜索小白,到初次涉猎,感觉每门技术都博大精深,其中精髓亦是不可一日而语.那小博猪就简单介绍一下这一周的学习历程,仅供各位程序猿们参考,这其中不涉及任何私密话题,因此也 ...

  8. Key/Value之王Memcached初探:三、Memcached解决Session的分布式存储场景的应用

    一.高可用的Session服务器场景简介 1.1 应用服务器的无状态特性 应用层服务器(这里一般指Web服务器)处理网站应用的业务逻辑,应用的一个最显著的特点是:应用的无状态性. PS:提到无状态特性 ...

  9. NoSQL初探之人人都爱Redis:(3)使用Redis作为消息队列服务场景应用案例

    一.消息队列场景简介 “消息”是在两台计算机间传送的数据单位.消息可以非常简单,例如只包含文本字符串:也可以更复杂,可能包含嵌入对象.消息被发送到队列中,“消息队列”是在消息的传输过程中保存消息的容器 ...

随机推荐

  1. Zap简单使用

    前言 zap 是 uber 开源的一个日志记录的包, uber 在 go 的领域建树颇多, zap 更是优秀, 相比于自带的 log ,他有更多的功能, 当然, 最显眼的还是他很快, 本文介绍 zap ...

  2. python学习笔记 | 猜拳游戏

    ''' @author: 人人都爱小雀斑 @time: 2020/3/6 18:52 @desc: 实验结果心得: 1.难点主要在判断谁输谁赢 2.挺好的 ''' import random d={1 ...

  3. 音视频入门-20-BMP、PNG、JPG、GIF静态图生成GIF动态图

    * 音视频入门文章目录 * 静态图 -> 动态图 前面 [18-手动生成一张GIF图片] 和 [19-使用giflib处理GIF图片] 生成的 GIF 每一帧都是一个颜色,平时用到的 GIF 每 ...

  4. kubernets与API服务器进行交互

    一  为何需要与kubernets集群的API服务器进行交互 1.1  kubernets提供了一种downapi的资源可以将pod的元数据渲染成环境变量或者downward卷的形式挂载到容器的文件系 ...

  5. AVA编程中button按钮,actionlistener和mouseClicked区别

    在java的编程中,对于按钮button 有两个事件: 1.actionPerformed 2.mouseClicked 区别: actionPerformed:一般事件,仅侦听鼠标左键的单击事件,右 ...

  6. LuoguP5488 差分与前缀和

    题意 给定一个长为\(n\)的序列\(a\),求出其\(k\)阶差分或前缀和.结果的每一项都需要对\(1004535809\)取模. 打表找规律 先看前缀和,设\(n=5\),\(k=4\),按照阶从 ...

  7. 《Go 语言并发之道》读后感 - 第四章

    <Go 语言并发之道>读后感-第四章 约束 约束可以减轻开发者的认知负担以便写出有更小临界区的并发代码.确保某一信息再并发过程中仅能被其中之一的进程进行访问.程序中通常存在两种可能的约束: ...

  8. 1.5V转3V电源芯片,1.5V转3V稳压芯片

    1.5V干电池的供电电压一般是0.9V-1.6V左右,因为供电电压不稳,所以需要1.5V转3V的稳压电源芯片,当0.9V-1.6V输入电压时,输出电压能稳定3V输出,给模块供电,MCU供电,LED灯供 ...

  9. mysql+MHA高可用

    MHA(Master High Availability)目前在MySQL高可用方面是一个相对成熟的解决方案,它由日本DeNA公司youshimaton(现就职于Facebook公司)开发,是一套优秀 ...

  10. mysql忽略表中的某个字段不查询

    业务场景 1.表中字段较多 2.查询不需要表中某个字段的数据 语句如下: SELECT CONCAT(' select ',GROUP_CONCAT(COLUMN_NAME),' from ', TA ...