[学习笔记]pb_ds库

前言

其实我很早开始就用pb_ds库了,用起来确实方便.但最近感觉还是对这个了解颇少,还是来补一下

话说有人会忘记头文件,其实这有个伎俩,找到电脑上的g++文件夹.Ubuntu应该在etc中,Windows的话各省应该都预装了Dev-CPP吧,右键打开文件位置

进入Dev-Cpp\MinGW32\lib\gcc\mingw32\4.8.1\include\c++

然后就发现一大堆头文件还有个叫pb_ds的文件夹,点进去又有大堆头文件,你按照相似方式ext/pb_ds/...加入你的代码就好了

当然也有个万能的#include<bits/extc++.h>不过有些可能不资瓷

哈希表

哈希表再也不用map/unordered_map实现了

调用

#include <ext/pb_ds/hash_policy.hpp>
#include <ext/pb_ds/assoc_container.hpp>
using namespace __gnu_pbds;
gp_hash_table <int,int>g;
cc_hash_table <int,int>c;

支持[]重载运算符,非常方便

gp_hash_table使用查探法,cc_hash_table使用拉链法

我一直是用gp_hash_table而且确实一般会稍快一点,然而昨天我做到了一道题毒瘤出题人8e5个数基本上是连续的

gp_hash_table就真的GG了,10s还没跑出来,cc_hash_table一下就跑完了

看了这篇文章才知道原因:https://blog.csdn.net/u011080472/article/details/51177412

所以我个人建议使用cc_hash_table

优先队列

这里只讲最常见的配对堆的使用,对其他种类的堆感兴趣的请自行了解

调用

#include <ext/pb_ds/priority_queue.hpp>
using namespace _gnu_pbds;
typedef pair<int,int> pii
typedef priority_queue < pii ,std::less<pii> ,pairing_heap_tag> Heap

这样Heap poi就让poi称为一个配对堆了

非常快

转载于:https://www.cnblogs.com/Rye-Catcher/p/9841814.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值