bitset 相关题目
#515. 「LibreOJ β Round #2」贪心只能过样例
题意: 给出 n 个数 \(x_i\), 每个数的取值范围为 \([a_i, b_i]\), 求 \(\sum{x_i^2}\) 的种类数. \(1 ≤ n ≤ 100, 1 ≤ a_i, b_i ≤ 100\).
思路: 直接状压的话需要枚举每个状态, 有了 bitset 之后就可以整体右移来转移了.
view code
#include <bits/stdc++.h>
using namespace std;
#define ll long long
#define inc(i, l, r) for (int i = l; i <= r; i++)
const int maxn = 105;
int n, a[maxn], b[maxn];
bitset<1000001> dp[maxn];
int main() {
ios::sync_with_stdio(false);
cin.tie(nullptr);
cin >> n;
inc(i, 1, n) cin >> a[i] >> b[i];
dp[0][0] = 1;
inc(i, 1, n) inc(j, a[i], b[i]) dp[i] |= dp[i - 1] << (j * j);
cout << dp[n].count() << "\n";
}
题意: 五维偏序.
思路: 用 bitset 维护每个维度排序后的标号前缀. 这个写法本质就是对暴力的优化. 复杂度 \(O(\frac{n^2}{w})\). 本题目 N 为3e4, 所以时间空间可以接受.
view code
#include <bits/stdc++.h>
using namespace std;
#define ll long long
#define inc(i, l, r) for (int i = l; i <= r; i++)
#define pii pair<int, int>
#define fi first
#define se second
#define pb push_back
const int maxn = 3e4 + 5;
int n;
pii p[6][maxn];
bitset<maxn> stu[6][maxn], ans;
int main() {
ios::sync_with_stdio(false);
cin.tie(nullptr);
cin >> n;
inc(i, 1, n) {
inc(j, 1, 5) {
cin >> p[j][i].fi;
p[j][i].se = i;
}
}
inc(i, 1, 5) sort(p[i] + 1, p[i] + n + 1);
inc(i, 1, 5) {
inc(j, 2, n) {
stu[i][p[i][j].se] = stu[i][p[i][j - 1].se];
stu[i][p[i][j].se].set(p[i][j - 1].se);
}
}
inc(i, 1, n) {
ans.set();
inc(j, 1, 5) ans &= stu[j][i];
cout << ans.count() << "\n";
}
}
分块的写法(只是试过 hiho 的数据, 5e4 的 Cogs 现在访问不了了, 不知道会不会T):
view code
#include <bits/stdc++.h>
using namespace std;
#define ll long long
#define inc(i, l, r) for (int i = l; i <= r; i++)
#define pii pair<int, int>
#define fi first
#define se second
#define pb push_back
const int maxn = 3e4 + 5;
const int block = 240;
int n;
int a[6][maxn];
pii p[6][maxn];
bitset<maxn> ans, tmp;
bitset<maxn> bit[6][240];
vector<int> cit[6][240];
int bel[maxn];
int main() {
ios::sync_with_stdio(false);
cin.tie(nullptr);
//freopen("try.in", "r", stdin);
//freopen("try2.out", "w", stdout);
cin >> n;
inc(i, 0, n - 1) {
inc(j, 0, 4) {
cin >> p[j][i].fi;
p[j][i].se = i;
a[j][i] = p[j][i].fi;
}
}
inc(i, 0, n - 1) bel[i] = i / block;
inc(i, 0, 4) sort(p[i], p[i] + n);
inc(i, 0, 4) {
bitset<maxn> w;
vector<int> v;
w.reset();
inc(j, 0, n - 1) {
w.set(p[i][j].se);
v.push_back(p[i][j].se);
if (j == n - 1 || bel[j] != bel[j + 1]) {
bit[i][bel[j]] = w;
cit[i][bel[j]] = v;
vector<int>().swap(v);
}
}
}
inc(i, 0, n - 1) {
ans.set();
inc(j, 0, 4) {
tmp.reset();
int f = (a[j][i] - 1) / block;
if (f) tmp |= bit[j][f - 1];
for (int k = 0; k < (int)cit[j][f].size(); k++) {
int id = cit[j][f][k];
if (id == i) break;
tmp.set(id);
}
ans &= tmp;
}
cout << ans.count() << "\n";
}
}
Codeforces - 1097F Alex and a TV Show
题意: 给出 n 个可重集, 有四种操作: 1.把一个集合设为一个数; 2.把一个集合变成另外两个集合的并; 3.把一个集合变为从另外两个集合中各取一个数的 gcd; 4.询问集合中某一个数的个数模2. n ≤ 1e5, 操作 q ≤ 1e6, 值域 7000.
思路: 做法是搬运的, 我并不会做. 如果用 bitset 维护每个集合, 此时不好处理操作3. 改变思路, 既然和 gcd 有关就令 bitset 维护每个集合的约数(此时仍是可重集, 并且已模2, 不然咋存), 考虑每个数出现的奇偶, 就会发现操作 2, 3 分别对应异或, 按位与. 而操作 4 要用莫比乌斯函数推导一下:
\]
在模 2 意义下 +1 和 -1 都是 1, 只要考虑那些莫比乌斯函数不为 0 的情况, 预处理出每一个数的含平方因子的倍数情况.
view code
#include <bits/stdc++.h>
using namespace std;
#define ll long long
#define inc(i, l, r) for (int i = l; i <= r; i++)
const int maxn = 1e5 + 5;
const int maxm = 7005;
int n, q, op, x, y, z;
bitset<7005> fac[maxm], mul[maxm], mu, a[maxn];
int main() {
ios::sync_with_stdio(false);
cin.tie(nullptr);
mu.set();
inc(i, 1, 7000) {
for (int j = 2; i * j * j <= 7000; j++) {
mu[i * j * j] = 0;
}
}
inc(i, 1, 7000) {
for (int j = 1; i * j <= 7000; j++) {
fac[i * j][i] = 1;
mul[i][i * j] = mu[j];
}
}
cin >> n >> q;
while (q--) {
cin >> op;
if (op == 1) {
cin >> x >> y;
a[x] = fac[y];
} else if (op == 2) {
cin >> x >> y >> z;
a[x] = a[y] ^ a[z];
} else if (op == 3) {
cin >> x >> y >> z;
a[x] = a[y] & a[z];
} else {
cin >> x >> y;
cout << (a[x] & mul[y]).count() % 2;
}
}
}
bitset 相关题目的更多相关文章
- LeetCode: Palindrome 回文相关题目
LeetCode: Palindrome 回文相关题目汇总 LeetCode: Palindrome Partitioning 解题报告 LeetCode: Palindrome Partitioni ...
- leetcode tree相关题目总结
leetcode tree相关题目小结 所使用的方法不外乎递归,DFS,BFS. 1. 题100 Same Tree Given two binary trees, write a function ...
- [LeetCode] 链表反转相关题目
暂时接触到LeetCode上与链表反转相关的题目一共有3道,在这篇博文里面总结一下.首先要讲一下我一开始思考的误区:链表的反转,不是改变节点的位置,而是改变每一个节点next指针的指向. 下面直接看看 ...
- [LeetCode] [链表] 相关题目总结
刷完了LeetCode链表相关的经典题目,总结一下用到的技巧: 技巧 哑节点--哑节点可以将很多特殊case(比如:NULL或者单节点问题)转化为一般case进行统一处理,这样代码实现更加简洁,优雅 ...
- 九度 Online Judge 之《剑指 Offer》一书相关题目解答
前段时间准备华为机试,正好之前看了一遍<剑指 Offer>,就在九度 Online Judge 上刷了书中的题目,使用的语言为 C++:只有3题没做,其他的都做了. 正如 Linus To ...
- 已知前序(后序)遍历序列和中序遍历序列构建二叉树(Leetcode相关题目)
1.文字描述: 已知一颗二叉树的前序(后序)遍历序列和中序遍历序列,如何构建这棵二叉树? 以前序为例子: 前序遍历序列:ABCDEF 中序遍历序列:CBDAEF 前序遍历先访问根节点,因此前序遍历序列 ...
- [LeetCode] 二叉树相关题目(不完全)
最近在做LeetCode上面有关二叉树的题目,这篇博客仅用来记录这些题目的代码. 二叉树的题目,一般都是利用递归来解决的,因此这一类题目对理解递归很有帮助. 1.Symmetric Tree(http ...
- LeetCode - 排列相关题目
1.获取全排列 https://leetcode.com/problems/permutations/submissions/ 按字典序输出: 这里用的是vector<int>,不是引用. ...
- 剑指offer编程题Java实现——面试题4后的相关题目
题目描述: 有两个排序的数字A1和A2,内存在A1的末尾有足够多的空余空间容纳A2.请实现一个函数,把A2中的所有数字插入到A1中并且所有的数字是排序的. 还是利用从后向前比较两个数组中的数字的方式来 ...
随机推荐
- 优雅的创建一个JavaScript库
这篇文章的目的是通过演示一个简单的例子来介绍在JS中实例化和定义一个库的正确方法,以优化他人编写或维护自己的JS库. 在我们深入之前,我做了两点假设: 你知道简单的JavaScript或C语言. 你不 ...
- mongoose .find().limit()返回undefined
当我们使用mongoose的find方法查询数据库的同时,可以使用limit方法来指定返回数据的条数. limit方法基本语法如下所示: >db.COLLECTION_NAME.find().l ...
- jsp内置对象(三)-----response对象
response对象 response对象包含了响应客户端请求的有关信息,但在JSP中很少直接用到它.他是HttpServletResponse类的实例,response对象具有页面作用域,即访问一 ...
- springmvc与swagger2
首先呢我们导入相关的jar包文件 为了方便copy我copy一份 <!-- 导入java ee jar 包 --> <dependency> ...
- Redis系列四 - 分布式锁的实现方式
前言 分布式锁一般有3中实现方式: 数据库乐观锁: 基于Redis的分布式锁: 基于ZooKeeper的分布式锁. 以下将详细介绍如何正确地实现Redis分布式锁. 可靠性 首先,为了确保分布式锁的可 ...
- 这样阅读STM32参考手册更高效
<STM32F103xxx参考手册>不需要全部阅读——没有时间的.建议选读,但是前几章必读.存储器和总线架构.电源控制.备份寄存器.复位和时钟控制,通用和复用功能I/O,中断和时间等等前几 ...
- 修改js文件,引发的404问题
记录一个bug,本地测不出来,客户后台却404,web测试可参考.(不知道是不是通用的) 先介绍下背景 我们是web产品,存在发布机.管理机.js文件,页面会引用到这些js文件.出于安全考虑,规定js ...
- Java并发编程学习前期知识下篇
Java并发编程学习前期知识下篇 通过上一篇<Java并发编程学习前期知识上篇>我们知道了在Java并发中的可见性是什么?volatile的定义以及JMM的定义.我们先来看看几个大厂真实的 ...
- 如何查看子线程中的GC Alloc
1)如何查看子线程中的GC Alloc2)Build时,提示安卓NDK异常3)如何获得ParticleSystem产生的三角形数量4)关于图片通道的问题5)GPUSkinning导致模型动画不平滑 M ...
- JavaScript 原型与继承
JavaScript 原型与继承 JavaScript 中函数原型是实现继承的基础.prototype.construct.原型链以及基于原型链的继承是面向对象的重要内容 prototype 原型即 ...