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中并且所有的数字是排序的. 还是利用从后向前比较两个数组中的数字的方式来 ...
随机推荐
- js笔记系列之--时间及时间戳
js入门系列之 时间及时间戳 时间及时间戳 时间及时间戳是js里面很常见的一个概念,在我们写前端页面的时候,经常会遇到需要获取当前时间的情况,所以,了解js中的时间概念非常重要.而时间戳是指格林威治时 ...
- 精简TTF字体、FontPruner、汉字字体瘦身(非字蛛)
20190726更新 标黄部分 网上比应用比较多的 字蛛 http://font-spider.org/ 本文使用了本机安装软件,得到瘦身后的 TTF 字体文件 准备工具: python : 我使用是 ...
- BUI Webapp用于项目中的一点小心得
接触BUI也有一段时间,也用在了移动端的项目开发中,总的来说,该框架用起来也挺灵活的,控件可以自由定制,前提是自己能认真地学习该框架的api,因为api里面说的东西比较详细,如果没有仔细看的,可能有些 ...
- 斐讯k2
降级方法 https://jingyan.baidu.com/article/ab69b27080990d2ca7189f0b.html 刷第三方固件方法 https://blog.csdn.net/ ...
- proteus pro 8.9 安装及汉化教程
最近由于网上上课老师要求我们自己安装proteus这款仿真软件,所以笔者也安装了最新款版的proteus pro 8.9,分享给大家安装心得,也包含汉化过程,希望大家能用软件好好学习. 备注:感谢博主 ...
- 安装mysql.so
1.---- cd /usr/local/src/php-5.5.34/ext/mysql/2.---- /usr/local/php5/bin/phpize3.---- ./configure ...
- scrapy的扩展件extensions
extensions.py文件 # -*- coding: utf-8 -*- # 该扩展会在以下事件时记录一条日志: # spider被打开 # spider被关闭 # 爬取了特定数量的条目(ite ...
- 【Python】2.11学习笔记 注释,print,input,数据类型,标识符
前面学了好多内存什么的知识,没什么用(我有眼不识泰山233 吐槽一句,这课简直就是讲给完全的编程小白听得 就从语言开始写吧(其实好多已经看过了,再来一遍 话说我已经忘了\(Markdown\)怎么写了 ...
- ASP.NET MVC5实现芒果分销后台管理系统(一):系统结构设计,集成AutoMapper,Log4net
在构思完系统思维脑图后,小墨回到家中,便摩拳擦掌开始了开发工作.要想迅速完成系统开发,前期系统设计和准备尤其重要,因为小墨做过太多大大小小的业务系统,准备工作也是十分顺利. 系统结构 整个系统工程结构 ...
- Natas7 Writeup(任意文件读取漏洞)
Natas7: 页面出现了两个选项,点击后跳转,观察url发现了page参数,猜测可能存在任意文件读取漏洞. 且源码给了提示,密码在/etc/natas_webpass/natas8 中. 将/etc ...