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 单点修改 思路 ...
随机推荐
- visual studio如何检查内存泄露?
Visual Studio有专门的插件叫做Visual Leak Detector (VLD)Visual Leak Detector for Visual C++ 2008/2010/2012/20 ...
- java 文件上传(图片上传)
1.FTP工具类 代码如下: package com.taotao.common.utils; import java.io.File; import java.io.FileInputStream; ...
- 使用HttpURLConnection多线程下载
1 import java.io.IOException; 2 import java.io.InputStream; 3 import java.io.RandomAccessFile; 4 imp ...
- 如何打一个RPM包
如何打一个RPM包 参考链接:RPM打包原理.示例.详解及备查 前言 本文只是一个RPM安装的例子,并没有对RPM做比较详尽的叙述,更为详尽的讲解,可以在上面的链接中找到. RPM是啥? RPM(Re ...
- vue 根据身份证计算出出生日期和判断性别
//获取生日和性别 getBirth(idCard) { var birthday = ""; if(idCard != null & ...
- 一、部署sqlserver
1.下载并挂载sqlserver镜像 2.填写秘钥:6GPYM-VHN83-PHDM2-Q9T2R-KBV83 3.默认下一步 4.勾选需要的功能 5.默认下一步 6.默认下一步 等待安装完成即可. ...
- client-go实战之一:准备工作
欢迎访问我的GitHub https://github.com/zq2599/blog_demos 内容:所有原创文章分类汇总及配套源码,涉及Java.Docker.Kubernetes.DevOPS ...
- git02
Git Gui的使用 Ssh key 介绍及使用 Ssh key介绍 我理解的就是每台电脑上会产生出一个ssh key,然后自己有一个远程账户,但是自己有可能有很多台电脑, 包括家里的电脑还有公司的电 ...
- Python常见问题 - 写入数据到 excel 报 ValueError: invalid literal for int() with base 10 错误
背景 在上写入数据到excel中,报了以下错误 出现原因 对于写入excel场景下出现该错误的话,很大概率是写入数据的单元格原本的数据格式有问题 解决方法 清理掉单元格的旧数据,然后再写入就可以了
- Configuration对象和SessionFactory会话池
一.加载核心配置文件方式 二.加载映射文件方式 三.SessionFactory相当于连接池 四.获取session会话 同一个线程中获取的session两种方法获取的是同一个session对象: 不 ...