【bzoj4184】shallot 线段树+高斯消元动态维护线性基
题目描述
小苗去市场上买了一捆小葱苗,她突然一时兴起,于是她在每颗小葱苗上写上一个数字,然后把小葱叫过来玩游戏。
输入
第一行一个正整数n表示总时间;第二行n个整数a1,a2...an,若ai大于0代表给了小葱一颗数字为ai的小葱苗,否则代表从小葱手中拿走一颗数字为-ai的小葱苗。
输出
输出共n行,每行一个整数代表第i个时刻的最大异或和。
样例输入
6
1 2 3 4 -2 -3
样例输出
1
3
3
7
7
5
题解
线段树+高斯消元动态维护线性基
由于线性基不支持删除操作,所以我们需要离线来处理。
我们注意到每个数出现的时间都是一段连续的区间,所以可以使用map维护每个数的开始时间和结束时间,并在这一段区间上插入这个数。
我们肯定不能暴力在每个时间点上插入,所以需要线段树来降低时间复杂度。
在线段树的每个节点上开一个vector,存储这个区间的线性基。对于每个操作,在对应的vector上使用高斯消元动态维护线性基。
查询时,可以遍历整棵线段树,对于叶子结点直接使用贪心的方法查询并输出。但是如果将父亲节点的线性基暴力插入到儿子节点的话会导致MLE,于是需要记录一个新的节点,每次相当于将该节点的线性基插入到这个新的节点中。具体见代码。
时间复杂度$O(n\log^2n)$
- #include <cstdio>
- #include <algorithm>
- #include <vector>
- #include <map>
- #define N 500010
- using namespace std;
- struct data
- {
- vector<int> v;
- void insert(int x)
- {
- int i;
- for(i = 0 ; i < v.size() ; i ++ )
- if((x ^ v[i]) < x)
- x ^= v[i];
- if(x)
- {
- v.push_back(x);
- for(i = v.size() - 1 ; i ; i -- )
- {
- if(v[i] > v[i - 1]) swap(v[i] , v[i - 1]);
- else break;
- }
- }
- }
- int calc()
- {
- int i , ans = 0;
- for(i = 0 ; i < v.size() ; i ++ )
- if((ans ^ v[i]) > ans)
- ans ^= v[i];
- return ans;
- }
- }S[N << 2] , emp;
- map<int , int> f;
- int a[N];
- void update(int b , int e , int a , int l , int r , int x)
- {
- if(b <= l && r <= e)
- {
- S[x].insert(a);
- return;
- }
- int mid = (l + r) >> 1;
- if(b <= mid) update(b , e , a , l , mid , x << 1);
- if(e > mid) update(b , e , a , mid + 1 , r , x << 1 | 1);
- }
- void query(int l , int r , int x , data t)
- {
- int i , mid = (l + r) >> 1;
- for(i = 0 ; i < S[x].v.size() ; i ++ ) t.insert(S[x].v[i]);
- if(l == r)
- {
- printf("%d\n" , t.calc());
- return;
- }
- query(l , mid , x << 1 , t) , query(mid + 1 , r , x << 1 | 1 , t);
- }
- int main()
- {
- int n , i , x;
- scanf("%d" , &n);
- for(i = 1 ; i <= n ; i ++ )
- {
- scanf("%d" , &a[i]);
- if(a[i] > 0) f[a[i]] = i;
- else update(f[-a[i]] , i - 1 , -a[i] , 1 , n , 1) , f[-a[i]] = 0;
- }
- for(i = 1 ; i <= n ; i ++ )
- if(a[i] > 0 && f[a[i]])
- update(f[a[i]] , n , a[i] , 1 , n , 1);
- query(1 , n , 1 , emp);
- return 0;
- }
【bzoj4184】shallot 线段树+高斯消元动态维护线性基的更多相关文章
- 【bzoj4568】[Scoi2016]幸运数字 树上倍增+高斯消元动态维护线性基
题目描述 A 国共有 n 座城市,这些城市由 n-1 条道路相连,使得任意两座城市可以互达,且路径唯一.每座城市都有一个幸运数字,以纪念碑的形式矗立在这座城市的正中心,作为城市的象征.一些旅行者希望游 ...
- HDU3949:XOR(高斯消元)(线性基)
传送门 题意 给出n个数,任意个数任意数异或构成一个集合,询问第k大个数 分析 这题需要用到线性基,下面是一些资料 1.高斯消元&线性基&Matirx_Tree定理 笔记 2.关于线性 ...
- bzoj2115 [Wc2011] Xor——高斯消元 & 异或线性基
题目:https://www.lydsy.com/JudgeOnline/problem.php?id=2115 异或两次同一段路径的权值,就相当于没有走这段路径: 由此可以得到启发,对于不同的走法, ...
- BZOJ 4184 线段树+高斯消元
思路: 线段树表示的是时间 每回最多log个段 区间覆盖 一直到叶子 的线性基 xor 一下 就是答案 一开始没有思路 看了这篇题解 豁然开朗 http://www.cnblogs.com/joyou ...
- BZOJ 4004: [JLOI2015]装备购买 [高斯消元同余 线性基]
和前两(一)题一样,不过不是异或方程组了..... 然后bzoj的新数据是用来卡精度的吧..... 所有只好在模意义下做啦 只是巨慢无比 #include <iostream> #incl ...
- 【bzoj2115】[Wc2011] Xor DFS树+高斯消元求线性基
题目描述 输入 第一行包含两个整数N和 M, 表示该无向图中点的数目与边的数目. 接下来M 行描述 M 条边,每行三个整数Si,Ti ,Di,表示 Si 与Ti之间存在 一条权值为 Di的无向边. 图 ...
- 【BZOJ-2460&3105】元素&新Nim游戏 动态维护线性基 + 贪心
3105: [cqoi2013]新Nim游戏 Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 839 Solved: 490[Submit][Stat ...
- BZOJ 2466: [中山市选2009]树( 高斯消元 )
高斯消元解异或方程组...然后对自由元进行暴搜.树形dp应该也是可以的... ------------------------------------------------------------- ...
- 【BZOJ】2466: [中山市选2009]树 高斯消元解异或方程组
[题意]给定一棵树的灯,按一次x改变与x距离<=1的点的状态,求全0到全1的最少次数.n<=100. [算法]高斯消元解异或方程组 [题解]设f[i]=0/1表示是否按第i个点的按钮,根据 ...
随机推荐
- java面试题(杨晓峰)---第二讲Exception和Error有什么区别?
本人总结: Exception和Error:正常问题和意外问题,以自行车举例:没气和爆胎. ①理解Throwable,Exception,Error的设计和分类. ②掌握哪些应用最广泛的子类, ③如何 ...
- UVA 11732 strcmp() Anyone (Trie+链表)
先两两比较,比较次数是两者相同的最长前缀长度*2+1,比较特殊的情况是两者完全相同时候比较次数是单词长度*2+2, 两个单词'末尾\0'和'\0'比较一次,s尾部'\0'和循环内'\0'比较一次. 因 ...
- netbackup如何手动获取主机ID证书。
如何手动获取主机ID证书. 文章:100039650 最后发布:2017-09-21 评分: 20 11 产品:NetBackup 问题 从NetBackup V8.1开始,管理员需要在证书颁发 ...
- hd - MFM/IDE 硬盘设备
描述 DESCRIPTION hd* 开头的设备是以裸模式(raw mode)访问MFM/IDE类型硬盘的块设备. 第一个IDE驱动控制器上的主盘(主设备号3)是 hda ;从盘是 hdb. 第二个I ...
- 谷歌浏览器 加安全地址 快捷方式加参数 chrome
--unsafely-treat-insecure-origin-as-secure="http://192.168.43.17:8080"
- 【Python学习之五】高级特性5(切片、迭代、列表生成器、生成器、迭代器)
5.迭代器 由之前的生成器可知,for循环用于可迭代对象:Iterable.包括集合数据类型: list.tuple.dict.set.str 等,以及两种生成器.判断迭代器,使用 isinstanc ...
- 06grep与find命令详解
1. grep 命令 grep 命令用于在文本中执行关键词搜索,并显示匹配的结果,格式为"grep [选项][文件]". grep 命令的参数及其作用如下: -b 将可执行文件(b ...
- thinkcmf5更新模板代码分析,解决模板配置json出错导致数据库保存的配置项内容丢失问题
private function updateThemeFiles($theme, $suffix = 'html') { $dir = 'themes/' . $theme; $themeDir = ...
- OC8051项目启动
- 22.Yii2.0框架多表关联一对一查询之hasOne
思路: 通过文章查它对应的分类信息 一对一的关系 控制器里 //一对一关联查询 public function actionRelatesone() { //方法一,hasOne() 用查一条文章的结 ...