【题解】DZY Loves Chinese II

不吐槽这题面了...

考虑如何维护图的连通性,如果把图的变成一颗的\(dfs\)生成树,那么如果把一个节点的父边和他接下来所有的返祖边删除,那么我们就可以确定图的连通性改变了。

考虑如何快速维护这个东西。

可以考虑这样

  • 对于每条非树边,给他一个随机数的权值。
  • 对于每条树边,他的权值是横跨他的所有非树边的\(xor\)和。

那么也就是说,将非树边的状态通过\(xor\)压缩2到其他树边上了。树边的权值是由与他有关的非树边决定的。

查询的时候建基底,如果有数到最后被基底表示出来了,连通性就发生了变化。

正确性(忽略随机数的影响)我不知道怎么说,分情况讨论吧。

  • 假设多条权值一样的在集合内

    • 可能都是树边->权值一样代表这些点在一条链上,一条链断开了\(\ge 2\)条边,就算有一条非树边的帮助,肯定发生了连通性的改变。

    • 可能有一条返祖边->树边的后路被切断了,切掉这两条边后,肯定有节点脱节了。

  • 假设不存在多条权值一样的在几何内,但是有的权值被线性基表示出来了

    • 说明有至少一个点,横跨他的所有返祖边都被切断了,自己的树边也被切断了。
  • 假设这些点是线性无关的,不存在被表示出来的情况

    • 说明不存在有点的返祖边和树边被同时切断,说明图的连通性没有改变。

这道题其实也启示了我们一个做题的技巧,可以利用线性基将许多状态都压缩起来。

最终时间复杂度\(O(32qk)\)很快了

#include<bits/stdc++.h>
using namespace std;
#define RP(t,a,b) for(register int t=(a),edd_=(b);t<=edd_;(t)++)
#define DRP(t,a,b) for(int t=(a),edd_=(b);t>=edd_;(t)--)
#define ERP(t,a) for(register int t=head[a];t!=-1;t=e[t].nx)
#define TMP template < class ccf>
typedef long long ll;
#define Max(a,b) ((a)>(b)?(a):(b)) TMP inline ccf qr(ccf b) {
char c=getchar();
int q=1;
ccf x=0;
while(c<48||c>57)
q=c==45?-1:q,c=getchar();
while(c>=48&&c<=57)
x=x*10ll+c-48,c=getchar();
return q==-1?-x:x; }
const int maxm=500005;
const int maxn=100005;
struct E {
int to,nx;
} e[maxm<<1];
int cnt(1);
int head[maxn];
inline void add(int fr,int to,bool f) {
cnt++;
e[cnt].to=to;
e[cnt].nx=head[fr];
head[fr]=cnt;
if(f)
add(to,fr,0);
}
int ew[maxm];
int dfn[maxn];
int had[maxn];
int timer; void dfs(int now,int last) {
dfn[now]=++timer;
ERP(t,now) {
if(e[t].to!=last) {
if(!dfn[e[t].to]) {
dfs(e[t].to,now);
had[now]^=had[e[t].to];
ew[t>>1]=had[e[t].to]; } else if(dfn[now]>dfn[e[t].to]) {
register int x=rand();
ew[t>>1]=x;
had[e[t].to]^=x;
had[now]^=x;
}
}
}
} int base[35];
int num[35];
inline int upd(int x) {
DRP(t,31,1) {
if(x&num[t]) {
if(base[t])
x^=base[t];
else {
base[t]=x;
break;
}
}
}
return x==0;
} int q,n,k,m;
int t1,t2,t3;
int sigma,temp; int main() {
memset(head,-1,sizeof head);
srand(19491001);
num[1]=1;
RP(t,2,32)
num[t]=num[t-1]<<1;
// cout<<(int)'0'<<' '<<(int)'9'<<' '<<(int)'-'<<endl;
n=qr(1);
m=qr(1); RP(t,1,m) {
t1=qr(1);
t2=qr(1);
add(t1,t2,1);
} dfs(1,0); q=qr(1);
RP(t0,1,q) {
k=qr(1);
temp=1;
memset(base,0,sizeof base);
RP(qaqqqq,1,k) {
register int x=ew[qr(1)^sigma];
if(upd(x))
temp=0;
}
sigma+=temp;
if(temp)
puts("Connected");
else
puts("Disconnected");
}
return 0;
}

【题解】DZY Loves Chinese的更多相关文章

  1. 【BZOJ3563/BZOJ3569】DZY Loves Chinese I/II(随机化,线性基)

    [BZOJ3563/BZOJ3569]DZY Loves Chinese I/II(随机化,线性基) 题面 搞笑版本 正经版本 题面请自行观赏 注意细节. 题解 搞笑版本真的是用来搞笑的 所以我们来讲 ...

  2. 【BZOJ3563/3569】DZY Loves Chinese II 线性基神题

    [BZOJ3563/3569]DZY Loves Chinese II Description 神校XJ之学霸兮,Dzy皇考曰JC. 摄提贞于孟陬兮,惟庚寅Dzy以降. 纷Dzy既有此内美兮,又重之以 ...

  3. 【BZOJ3569】DZY Loves Chinese II

    [BZOJ3569]DZY Loves Chinese II 题面 bzoj 题目大意: 给你一张\(N(1\leq N\leq 10^5)\)个点\(M(1\leq M\leq 5\times 10 ...

  4. BZOJ 3563 DZY Loves Chinese

    Description 神校XJ之学霸兮,Dzy皇考曰JC. 摄提贞于孟陬兮,惟庚寅Dzy以降. 纷Dzy既有此内美兮,又重之以修能. 遂降临于OI界,欲以神力而凌♂辱众生. 今Dzy有一魞歄图,其上 ...

  5. [BZOJ3569]DZY Loves Chinese II(随机化+线性基)

    3569: DZY Loves Chinese II Time Limit: 5 Sec  Memory Limit: 64 MBSubmit: 1515  Solved: 569[Submit][S ...

  6. 题解-bzoj3569 DZY Loves Chinese II

    Problem bzoj 题意概要:给定\(n\)点\(m\)边无向连通图,\(Q\)次询问删除\(k\)条边后是否仍然连通,强制在线 Solution 半年前考到过这类题目(询问删除任意两条边使得图 ...

  7. 3563: DZY Loves Chinese - BZOJ

    Description神校XJ之学霸兮,Dzy皇考曰JC.摄提贞于孟陬兮,惟庚寅Dzy以降.纷Dzy既有此内美兮,又重之以修能.遂降临于OI界,欲以神力而凌♂辱众生. 今Dzy有一魞歄图,其上有N座祭 ...

  8. BZOJ 3569 DZY Loves Chinese II

    Description 神校XJ之学霸兮,Dzy皇考曰JC. 摄提贞于孟陬兮,惟庚寅Dzy以降. 纷Dzy既有此内美兮,又重之以修能. 遂降临于OI界,欲以神力而凌♂辱众生. 今Dzy有一魞歄图,其上 ...

  9. 【BZOJ 3569】 DZY Loves Chinese II

    题目连接: 传送门 题解: 先%一发大佬的题解. 考虑一个图,删除一些边以后不连通的条件为,某个联通块与外界所有连边都被删掉,而不只是生成树中一个树边与所以覆盖它的非树边(很容易举出反例). 那么考虑 ...

随机推荐

  1. POJ 3368 Frequent values 线段树与RMQ解法

    题意:给出n个数的非递减序列,进行q次查询.每次查询给出两个数a,b,求出第a个数到第b个数之间数字的最大频数. 如序列:-1 -1 1 1 1 1 2 2 3 第2个数到第5个数之间出现次数最多的是 ...

  2. xampp 安装 mysql-python

    在已经安装brew前提下:brew install mysql-connector-c pip install MySQL-python

  3. ERROR 2002 (HY000): Can't connect to local MySQL server through socket '/tmp/mysql.sock'

    原因:找不到mysql.sock文件 解决方法: 1 找到mysql.sock文件位置 echo "show variables" | mysql | grep "soc ...

  4. 清空catalina.out报错Permission denied

    今天在清空catalina.out的时候报错 [yangkun@sg logs]$ sudo echo '' > catalina.out -bash: catalina.out: Permis ...

  5. 安卓获取软硬件信息并上传给server(Socket实现)

    首先,项目结构如图--A:分为client部分CheckInfo和server端CheckInfo_Server.CheckInfo获取手机信息(Mac,Cpu,内存,已安装软件信息等)并上传到ser ...

  6. BEGINNING SHAREPOINT&#174; 2013 DEVELOPMENT 第9章节--client对象模型和REST APIs概览 client对象模型(CSOM)基础

    BEGINNING SHAREPOINT® 2013 DEVELOPMENT 第9章节--client对象模型和REST APIs概览  client对象模型(CSOM)基础         在SP2 ...

  7. JavaScript中给二维数组动态添加元素的质朴方法

    var myData = new Array(); for(var i=0;i<tableDatas.length;i++){ var arr=tableDatas[i]; ...... /// ...

  8. Command terminated by signal 11

    Command terminated by signal 11可能的情况之中的一个是数组越界.你在訪问不被同意的内存空间.

  9. 如何在vs2010中添加Picture控件

    1.新建项目,并在对话框控件中拖入picture控件,并做如下设置 2.在picture控件的属性栏需要进行如下修改:ID需要修改,不能为static ID是控件的唯一标识,PictureCtrl(p ...

  10. React学习之redux

    在阅读本文之前,希望大家对以下知识点能提前有所了解并且上好厕所(文章有点长): 状态提升的概念 react高阶组件(函数) es6基础 pure 组件(纯函数) Dumb 组件 React.js的co ...