关于 bitset 的一些题目

参考

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\) 的倍数。

原文地址:https://www.cnblogs.com/ftae/p/9296600.html

时间: 2024-10-31 12:50:37

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

BZOJ3687:bitset STL

[bzoj3687][FJ2014集训]简单题 2014年9月14日1,8212 [题目描述]小呆开始研究集合论了,他提出了关于一个数集四个问题:1. 子集的异或和的算术和.2. 子集的异或和的异或和.3. 子集的算术和的算术和.4. 子集的算术和的异或和.目前为止,小呆已经解决了前三个问题,还剩下最后一个问题还没有解决,他决定把这个问题交给你,未来的集训队队员来实现.[输入格式]从 xor.in 中输入数据第一行,一个整数 n.第二行,n 个正整数,表示 a1, a2, …, an[输出格式]

[luoguP2447] [SDOI2010]外星千足虫(高斯消元 + bitset)

传送门 用bitset优化,要不然n^3肯定超时 消元过程中有几点需要注意,找到最大元后break,保证题目中所说的K最小 如果有自由元说明解很多,直接返回 #include <bitset> #include <cstdio> #define N 2050 #define max(x, y) ((x) > (y) ? (x) : (y)) int n, m, ans; std::bitset <N> s[N]; char S[N][N]; inline int

【分块】【bitset】hdu6085 Rikka with Candies

给你数组A和B,A B中的元素大小都不超过5w,且两两不同. q次询问,每次给你个k,问你有多少对(i,j),满足A(i)%B(j)==k. 如题目所言模拟bitset的过程,实质上是个分块,每块的大小定为63. 一个小技巧是对于最终的那个数组w,分块后记63个w数组,每个数组最前面一块是零散的部分,大小从1~63,这样比较好操作. 最后把63个w里面的每一位的值都异或起来,就是对应的k的答案. #include<cstdio> #include<cstring> #include

bzoj 3687 简单题 - bitset

Description 小呆开始研究集合论了,他提出了关于一个数集四个问题: 1.子集的异或和的算术和. 2.子集的异或和的异或和. 3.子集的算术和的算术和. 4.子集的算术和的异或和.     目前为止,小呆已经解决了前三个问题,还剩下最后一个问题还没有解决,他决定把 这个问题交给你,未来的集训队队员来实现. Input 第一行,一个整数n. 第二行,n个正整数,表示01,a2….,. Output 一行,包含一个整数,表示所有子集和的异或和. Sample Input 21 3 Sampl

Codeforces 788C The Great Mixing(背包问题建模+bitset优化或BFS)

[题目链接] http://codeforces.com/problemset/problem/788/C [题目大意] 给出一些浓度的饮料,要求调出n/1000浓度的饮料,问最少需要多少升饮料 [题解] 设浓度为a,现在要求出系数x1,x2,x3……,使得x1*a1+x2*a2+x3*a3+……=n*(x1+x2+x3+……) 得a1*(x1-n)+a2*(x2-n)+a3*(x3-n)+……=0 假设现在有x1-n和x2-n,设其数值为x和y,那么一定有(x)*y+(-y)*x=0, x+y

hdu_5890_Eighty seven(bitset优化DP)

题目链接:hdu_5890_Eighty seven 题意: 50个数,10W个询问,每次问删掉第i,j,k个数后,是否存在一种选10个数和为87的方案,只需要输出 ’Yes’ 或者 ’No’ 题解: 暴力:不同的询问大概2W个,每个暴力bitset DP,抠一抠能卡着过.优化1:先求出一组解,如果询问和解没交就是’Yes’,否则暴力,不同的询问大概1W个:优化2:先预处理出所有询问的答案,能方便的复用之前的DP数组,不用每次从头开始重新求. 以上是camp的题解 这里学习了一下bitset,把

ACM题目————The Blocks Problem

代码参考:http://www.hankcs.com/program/uva-q101-the-blocks-problem.html Description Background Many areas of Computer Science use simple, abstract domains for both analytical and empirical studies. For example, an early AI study of planning and robotics

[POJ 2443] Set Operation (bitset)

题目链接:http://poj.org/problem?id=2443 题目大意:给你N个集合,每个集合里有若干个数.M个查询,每个查询有a,b两个数.问是否存在一个集合同时包含a,b这两个数.若存在则输出Yes,否则为No. 康神竟然一下子就想出来了.. 思路:统计每个数在哪个集合出现过,用bitset记录下来.然后对于a,b,则把两个bitset取与. 如果得到空集就是No,否则就是Yes. 1 #include <cstdio> 2 #include <bitset> 3 #

Bitset小结 (POJ2443 &amp; HDU4920)

学了下bitset用法,从网上找的一些bitset用法,并从中调出一些常用的用法. 构造函数bitset<n> b; b有n位,每位都为0.参数n可以为一个表达式.如bitset<5> b0;则"b0"为"00000"; bitset<n> b(unsigned long u); b有n位,并用u赋值;如果u超过n位,则顶端被截除如:bitset<5>b0(5);则"b0"为"00101&