参考

bitset

bitset<MAXN> b;
b.any() // b中是否存在置为1的二进制位。
b.none() // b中是否不存在置为1的二进制位。
b.count() // b中置为1的二进制位的个数。
b.size() // b中二进制位数的个数。
b[pos] // 访问b中在pos处二进制位。
b.test(pos) // b中在pos处的二进制位置为1么?
b.set() // 把b中所有二进制位都置为1。
b.set(pos) // 把b中在pos处的二进制位置为1。
b.reset() // 把b中所有二进制位都置为0。
b.reset(pos) // 把b中在pos处的二进制位置置为0。
b.flip() // 把b中所有二进制位逐位取反。
b.flip(pos) // 把b中在pos处的二进制位取反。
b.to_ullong() // 返回一个有相同二进制位的 unsigned long long 类型的值。

想法

一般先考虑题目的暴力做法,如果复杂度有 \(1e9\) ,这时候就可能考虑 \(bitset\) 优化,一般题目中的关系类似于能不能?是不是?这种,或者可以用 \(bitset\) 优化 \(DP\)(背包 \(DP\) 比较多,或者用于记录路径之类) ,一个有趣的应用是对于一些字符串问题,字符串长度不长,但是动态更新,询问次数很多的情况,可以维护 \(bitset\) 进行快速求解。

题目

  • Triatrip
  • Bipartite Graph 显然二分图两边点数要尽可能相同,考虑 01背包DP, \(bitset\) 优化,二进制位 \(i\) 表示是否能构成点数量为 \(i\) 的一边。
  • Addition on Segments 先进行类似于线段树的更新操作,然后用 \(bitset\) 加速状态转移。
  • Explosion \(bitset\) 加速传递闭包的计算。
  • Eighty seven 考虑前缀后缀,开两个 \(bitset\) 类型的 \(DP\) 数组,以前缀为例,\(dp[i][j][k]\) 表示到第 \(i\) 个数,一定不选 \(j\) 这个位置上的数,选了 \(k\) 个数时所有可能的和(二进制位为\(1\)表示有这样的和)。对于后缀的数组,如果二进制位 \(i\) 上的数字为\(1\),可修改为 \(bit[87-i]=1\),那么对于询问,枚举 \(k\) ,将前缀后缀按位与,检查是否有二进制位为\(1\)。
  • Price List Strike Back
  • Judgement 01背包 \(DP\),\(bitset\) 记录路径。
  • 带可选字符的多字符串匹配 \(bitset\) 加速匹配。预处理不同字符可能出现的集合,如果到主串上的第 \(i\) 个字符,有 \(bit[j]=1\) 表示已经匹配了长度为 \(j\) 的模板串。\(bit<<1\) 等价于加入一个新的字符,利用前面的预处理可以判断转移是否合法(按位与),若不合法则对应的二进制位会变成 \(0\)。
  • The Values You Can Make 背包 \(DP\) 。
  • La Vie en rose \(bitset\) 优化字符串匹配。
  • Nearest Maintenance Point 在最短路搜索的过程中使用 \(bitset\) 记录信息,表示从哪些点到当前点有最短路。
  • Rikka with Candies 离线查询。由于 \(a \% b = k\), \(0\leq k < b\),我们可以从大到小枚举这个 \(k\) ,统计答案,然后更新 \(bitset\) 中 \(k\) 的倍数。

关于 bitset 的一些题目的更多相关文章

  1. C++ STL bitset总结

    基础用法 C++ Reference 神犇博客 余下的就是例题了 [BZOJ3687]简单题 考虑\(DP\),设\(f[i][j]\)表示前\(i\)个元素的算数和为\(j\)的子集个数,有: \[ ...

  2. 浅析 c++ bitset 的用法

    浅析 c++ bitset 的用法 总述 C++的 \(bitset\) 位于 <bitset> 头文件中,这是一种类似于数组的数据结构,每个位置存储 \(0\ or\ 1\) ,并且每个 ...

  3. bitset 相关题目

     std::bitset 的语法就不搬运了, 直接看题吧   #515. 「LibreOJ β Round #2」贪心只能过样例 题意: 给出 n 个数 \(x_i\), 每个数的取值范围为 \([a ...

  4. DFS序+线段树+bitset CF 620E New Year Tree(圣诞树)

    题目链接 题意: 一棵以1为根的树,树上每个节点有颜色标记(<=60),有两种操作: 1. 可以把某个节点的子树的节点(包括本身)都改成某种颜色 2. 查询某个节点的子树上(包括本身)有多少个不 ...

  5. (DFS、bitset)AOJ-0525 Osenbei

    题目地址 简要题意: 给出n行m列的0.1矩阵,每次操作可以将任意一行或一列反转,即这一行或一列中0变为1,1变为0.问通过任意多次这样的变换,最多可以使矩阵中有多少个1. 思路分析: 行数比较小,先 ...

  6. Gym 100917J---Judgement(01背包+bitset)

    题目链接 http://codeforces.com/gym/100917/problem/J Description standard input/outputStatements The jury ...

  7. 74 使用BitSet输出数组中的重复元素

    [本文链接] http://www.cnblogs.com/hellogiser/p/using-bitset-to-print-duplicate-elements-of-array.html [题 ...

  8. Codeforces Gym 100342J Problem J. Triatrip 求三元环的数量 bitset

    Problem J. Triatrip Time Limit: 20 Sec Memory Limit: 256 MB 题目连接 http://codeforces.com/gym/100342/at ...

  9. ACM题目————A simple problem

    Description Zty很痴迷数学问题..一天,yifenfei出了个数学题想难倒他,让他回答1 / n.但Zty却回答不了^_^. 请大家编程帮助他.   Input 第一行整数T,表示测试组 ...

随机推荐

  1. 数学:FFT

    在信息学竞赛中FFT只有一个用处那就是加速多项式的乘法 多项式乘法原本的时间复杂度是O(n^2)的,然后经过FFT之后可以优化为O(nlogn) FFT就是将系数表示法转化成点值表示法相乘,再由点值表 ...

  2. (4.2)基于LingPipe的文本基本极性分析【demo】

    酒店评论情感分析系统(四)—— 基于LingPipe的文本基本极性分析[demo] (Positive (favorable) vs. Negative (unfavorable)) 这篇文章为Lin ...

  3. HDFS默认副本数为什么是3

    转载自: https://www.cnblogs.com/bugchecker/p/why_three_replications_for_HDFS_in_engineer.html HDFS采用一种称 ...

  4. Python :集合类型(set)

    set 是一个无序的元素集合,支持并.交.差及对称差等数学运算, 但由于 set 不记录元素位置,因此不支持索引.分片等序列的操作. 一.初始化 s0 = set() d0 = {} s1 = {0} ...

  5. 二叉树的层序遍历(levelordertraverse)

    数据结构关于二叉树的遍历还有一种层序遍历,按层次依次输出元素.最上层最先输出,同层中最左最先输出,使用队列这一结构来实现: int levelOrderTraverse(IDTree *pTree) ...

  6. 目标检测-基于Pytorch实现Yolov3(1)- 搭建模型

    原文地址:https://www.cnblogs.com/jacklu/p/9853599.html 本人前段时间在T厂做了目标检测的项目,对一些目标检测框架也有了一定理解.其中Yolov3速度非常快 ...

  7. struct msghdr和struct cmsghdr【转载】

    理解struct msghdr当我第一次看到他时,他看上去似乎是一个需要创建的巨大的结构.但是不要怕.其结构定义如下:struct msghdr {    void         *msg_name ...

  8. Term Term ssh登陆linux后 显示乱码

    setup----terminal----locale----“chinese” OK!!!!!

  9. linux中的计算【转】

    shell中的赋值和操作默认都是字符串处理,在此记下shell中进行数学运算的几个特殊方法,以后用到的时候可以来看,呵呵 1.错误方法举例 a) var=1+1 echo $var 输出的结果是1+1 ...

  10. 多个id或class属性相同的元素绑定事件

    <td class="tools"><a href="javascript:void(0);" status="0" na ...