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中并且所有的数字是排序的. 还是利用从后向前比较两个数组中的数字的方式来 ...
随机推荐
- PostgreSQL与MySQL对比
都属于开放源码的一员,性能和功能都在高速地提高和增强.MySQL AB的人们和PostgreSQL的开发者们都在尽可能地把各自的数据库改得越来越好,所以对于任何商业数据库使用其中的任何一个都不能算是错 ...
- 不要忽视Managed code stripping的副作用
0x00 前言 Unity 2018.3之后,新的“Managed Stripping Level”选项将替换 player settings 中原有的“Stripping Level”选项. 这个新 ...
- 7-34 jmu-python-是否偶数 (10 分)
输入一个整数,判断是否偶数 输入样例: 7 输出样例: 7不是偶数 输入样例: 8 输出样例: 8是偶数 a = int(input()) if (a % 2 == 0): print('%d是偶数' ...
- 解决Ajax中IE浏览器缓存问题
解决Ajax中IE浏览器缓存问题 1.首先,先看一张图.从这张图中我们可以清楚的了解到从请求的发出到解析响应的过程. 2.根据图中的三个节点我们可以使用三种方式解决这个缓存问题(主要是针对ie) 2. ...
- drf呼啦圈
呼啦圈 1.1 表结构设计 不会经常变化的值放在内存:choices形式,避免跨表性能低. 分表:如果表中列太多/大量内容可以选择水平分表 表自关联 from django.db import mod ...
- 升级到Chrome 80+的SameSite问题,及Asp.net站点修改
缘起 有用户反映,之前正常使用的站点,出现无法登录情况. 调查 用户使用场景,使用iframe嵌套了我们的Web,跨在一个跨域 用户升级了最新的Chrome 80 根据浏览记录看到,Post请求没有发 ...
- seldom之数据驱动
seldom之数据驱动 如果自动化某个功能,测试数据不一样而操作步骤是一样的,那么就可以使用参数化来节省测试代码. seldom是我在维护一个Web UI自动化测试框,这里跟大家分享seldom参数化 ...
- Java-字符流练习。(新手)
参考手册: 关键字: write() 写入存取 close() 结束 flush() 刷新缓冲区(缓冲区就是临时存放数据的区域.) currentTimeMillis() 返回以毫秒为 ...
- 给 ABP vNext 应用安装私信模块
在上一节五分钟完成 ABP vNext 通讯录 App 开发 中,我们用完成了通讯录 App 的基础开发. 这本章节,我们会给通讯录 App 安装私信模块,使不同用户能够通过相互发送消息,并接收新私信 ...
- 聊一聊 React 中的 CSS 样式方案
和 Angular,Vue 不同,React 并没有如何在 React 中书写样式的官方方案,依靠的是社区众多的方案.社区中提供的方案有很多,例如 CSS Modules,styled-compone ...