YbtOJ#883-最大的割【带修线性基】
正题
题目链接:http://www.ybtoj.com.cn/contest/118/problem/3
解题思路
给出\(n\)个点,\(m\)次动态插入一条无向边询问:割掉一些边使得图中至少两点不连通,并且割掉的边异或和最大。
询问之间相互独立
\(1\leq n\leq 500,1\leq m\leq 1000\)
边权以二进制形式给出,长度不超过\(1000\)
解题思路
要求分隔两个点,看起来很麻烦,其实有个结论。先定义\(w_i\)表示连接\(i\)的所有边的异或和,如果选出了一个点集\(U\)和外面的所有点都隔绝,那么割就是点集\(U\)中所有点的\(w_i\)值异或和。
其实挺显然的,因为如果两个点集中的点\(x,y\)之间的边被异或了两次就抵消掉了。
那么现在问题就变为了每次修改两个数,求最大异或和。
然后就是带修线性基的裸题了,有两种方法
在线做法是先删除再插入,就是开一个0行储存所有的没有成功插入线性基的元素,然后还要对于每个元素维护一个它插入的时候异或了哪些元素。
每次你删除一个元素\(x\)的时候,假设集合\(S\)中储存了所有插入的时候异或了\(x\)的元素(包括\(x\)本身),那么我们找出一个最小的\(y\in S\)(异或后),让所有\(S\)中的其他元素异或上\(y\)之后再将\(y\ xor\ c\)插入(\(c\)表示你要让\(x\)异或的值)
此时就相当于你将之前插入\(x\)时本应该异或的数变成了异或\(x\ xor\ c\)的,选出最小的\(y\)防止对后面的元素产生影响,然后修改后让\(y\)代替\(x\)成为新的主元插入。
加一个\(bitset\)优化,时间复杂度\(O(\frac{m(n+L)L}{w})\)
离线的做法是线段树分治,一个\(x\)的取值会被分为不同的时间段,每次将\(x\)的固定的时间段插入到线段树的对应区间,然后分治下去的时候维护一个撤销线性基就好了。
时间复杂度\(O(\frac{mL^2\log m}{w})\)(也许?)
这里写的是在线的做法
code
#include<cstdio>
#include<cstring>
#include<algorithm>
#include<bitset>
using namespace std;
const int N=1010;
bitset<N>w[N],v[N],c,ans;
int n,m,p[N];char s[N];
void Insert(int x){
for(int i=N-1;i>=0;i--)
if(w[x][i]){
if(p[i])w[x]^=w[p[i]],v[x]^=v[p[i]];
else{p[i]=x;return;}
}
return;
}
void Change(int x){
int pos=0;
for(int i=1;i<=n;i++)
if(v[i][x]&&!w[i].any()){pos=i;break;}
if(!pos)
for(int i=0;i<N;i++)
if(p[i]&&v[p[i]][x]){pos=p[i];p[i]=0;break;}
for(int i=1;i<=n;i++)
if(v[i][x]&&i!=pos)
w[i]^=w[pos],v[i]^=v[pos];
w[pos]^=c;
Insert(pos);return;
}
int main()
{
freopen("cut.in","r",stdin);
freopen("cut.out","w",stdout);
scanf("%d%d",&n,&m);
for(int i=1;i<=n;i++)v[i][i]=1;
for(int i=1;i<=m;i++){
int x,y;
scanf("%d%d",&x,&y);scanf("%s",s);
int l=strlen(s);c.reset();
for(int j=0;j<l;j++)c[j]=s[l-j-1]-'0';
Change(x);
Change(y);bool flag=0;
ans.reset();
for(int i=N-1;i>=0;i--){
if(p[i]&&!ans[i])ans^=w[p[i]];
if(ans[i])flag=1;
if(flag)printf("%d",ans[i]?1:0);
}
if(!flag)puts("0");
else putchar('\n');
}
return 0;
}
YbtOJ#883-最大的割【带修线性基】的更多相关文章
- 【BZOJ4184】shallot(线段树分治,线性基)
[BZOJ4184]shallot(线段树分治,线性基) 题面 权限题啊.....好烦.. Description 小苗去市场上买了一捆小葱苗,她突然一时兴起,于是她在每颗小葱苗上写上一个数字,然后把 ...
- 【BZOJ-3052】糖果公园 树上带修莫队算法
3052: [wc2013]糖果公园 Time Limit: 200 Sec Memory Limit: 512 MBSubmit: 883 Solved: 419[Submit][Status] ...
- 【BZOJ-1146】网络管理Network DFS序 + 带修主席树
1146: [CTSC2008]网络管理Network Time Limit: 50 Sec Memory Limit: 162 MBSubmit: 3495 Solved: 1032[Submi ...
- 主席树套树状数组——带修区间第k大zoj2112
主席树带修第k大 https://www.cnblogs.com/Empress/p/4659824.html 讲的非常好的博客 首先按静态第k大建立起一组权值线段树(主席树) 然后现在要将第i个值从 ...
- 「洛谷1903」「BZOJ2120」「国家集训队」数颜色【带修莫队,树套树】
题目链接 [BZOJ传送门] [洛谷传送门] 题目大意 单点修改,区间查询有多少种数字. 解法1--树套树 可以直接暴力树套树,我比较懒,不想写. 稍微口胡一下,可以直接来一个树状数组套主席树,也就是 ...
- BZOJ2120 数颜色 莫队 带修莫队
原文链接https://www.cnblogs.com/zhouzhendong/p/BZOJ2120.html 题目传送门 - BZOJ2120 题意 给定一个长度为 $n$ 的序列 $a$ ,有 ...
- BZOJ3052/UOJ#58 [wc2013]糖果公园 莫队 带修莫队 树上莫队
原文链接https://www.cnblogs.com/zhouzhendong/p/BZOJ3052.html 题目传送门 - BZOJ3052 题目传送门 - UOJ#58 题意 给定一棵树,有 ...
- UVA 12345 Dynamic len(带修莫队)
Dynamic len [题目链接]Dynamic len [题目类型]带修莫队 &题解: 莫队可以单点更改,只要再多加一维,代表查询次数,排序的时候3个关键字. 之后循环离线的时候,先暴力时 ...
- bzoj 2120 数颜色 (带修莫队)
题目链接: https://www.lydsy.com/JudgeOnline/problem.php?id=2120 题意:两种操作:Q 询问区间 l - r 内颜色的种类 ,R 单点修改 思路 ...
随机推荐
- vlc播放器设置开机自动全屏播放网络视频流
因工作需要,要用vlc视频播放器实现开机自动全屏播放某个网络视频流.百度了下,说的都很模糊,经过整理,设置方法如下: 一,添加视频流地址:rtsp://wowzaec2demo.streamlock. ...
- 在Activity和附贴的Fragment中同时使用多Surface错乱解决
SurfaceView因为独特的双缓冲机制,在android应用中十分普遍,视频播放器.摄像机预览等都会用到,如果在两个Fragment或者一个Fragment和Activity同时使用都会造成无法正 ...
- C#简单实现表达式目录树(Expression)
1.什么是表达式目录树 :简单的说是一种语法树,或者说是一种数据结构(Expression) 2.用Lambda声明表达式目录树: 1 2 3 4 5 Expression<Func<in ...
- linux 常用命令(三)——(centos7)MySql 5.7添加用户、删除用户与授权
一.创建用户:以root用户登录到数据库进行用户创建 命令: CREATE USER 'username'@'host' IDENTIFIED BY 'password'; 例如: CREATE US ...
- urllib3中学到的LRU算法
介绍 urllib3._collections.py::RecentlyUserContainer类,是一个线程安全的Dict类容器,用来维护一定数量(maxsize)的Key-Value映射, 当数 ...
- 使用Visual Studio分析dump
最近系统是不是CPU会飙升的百分之九十多甚至百分百,在本地又很难复现问题,无法定位问题出现在哪. 可以用转储文件来保存现场,然后通过分析dump文件可以大概分析出问题的所在 生成转存文件 在CPU飙升 ...
- BST B树 B+树
二叉排序树/二叉搜索树 (BST) 定义 左子树节点值<根节点值<右子树节点值 默认不允许两个节点的关键值相同 进行中序遍历可以得到递增的有序序列 查找效率 取决与树的高度,最好O(log ...
- 使用栅格系统开发响应式页面——logo+nav实例
小屏时: 中屏及以上时: <!DOCTYPE html> <html> <head> <meta charset="utf-8"> ...
- indexedDB数据库完整创建流程
1.打开数据库 使用 IndexedDB 的第一步是打开数据库,使用indexedDB.open()方法 var request = window.indexedDB.open(databaseNam ...
- Redis实现主从复制以及sentinel的配置
redis 是一个高性能的 key-value 数据库. redis 的出现,很大程度补偿了 memcached 这类 keyvalue 存储的不足,在部分场合可以对关系数据库起到很 好的补充作用.它 ...