题面在这里!

这两个其实是一个题啦。。双倍经验加成23333

可以很简单的发现如果把一条树边和所有覆盖它的非树边都删去的话,那么图会不连通;

如果再手玩一下可以发现,如果把两个被非树边覆盖的集合相同的树边删去,图也是会不连通的。

于是大胆猜想一波,我们给每条边附上一个非树边集合,里面的边就是它被哪些非树边覆盖,特殊的如果这条边本来就是非树边那么这个集合里只有它一个。。。

只有询问中删去的边的集合存在至少一个子集,满足里面所有边的非树边集合的异或为空(应该说对称差?),那么图不连通。

显然bitset可以保证正确性,但是太慢了会GG掉。。。

于是我们可以延用某oj某月的月赛的一道叫对称数的题的套路,给每条非树边随机一个 < 2^64 的边权,然后集合的权值可以表示成集合内所有非树边边权的异或,于是集合异或为空就相当于要所有集合的权值的异或和为0,线性基判一判就好啦。

如果想让这个算法出现偏差,那么当且仅当 存在一个非树边的集合 使得集合的权值为0。

也就是二进制每一位都是0,那么这个概率显然是 1/2^64  (注意这个集合大小无关,因为杨辉三角同一行的奇数列的和永远是总和的1/2 (第0行除外))。

并且就算存在了,询问也不一定询问的到啊QWQ,所以就当成几乎不会错啦。

#include<bits/stdc++.h>
#define ll unsigned long long
using namespace std;
const int N=100005; inline int read(){
int x=0; char ch=getchar();
for(;!isdigit(ch);ch=getchar());
for(;isdigit(ch);ch=getchar()) x=x*10+ch-'0';
return x;
} int hd[N],to[N*10],ne[N*10],dc;
int num=1,n,m,Q,cnt,K,L,dfn[N];
ll val[N*10],a[66],Xor[N],c[66];
bool flag; inline void add(int x,int y){ to[++num]=y,ne[num]=hd[x],hd[x]=num;} inline ll getrand(){ return (ll)floor(rand()/(double)RAND_MAX*(double)1e19);} void dfs(int x,int fa){
dfn[x]=++dc;
for(int i=hd[x];i;i=ne[i]) if(to[i]!=fa)
if(!dfn[to[i]]){
dfs(to[i],x),Xor[x]^=Xor[to[i]];
val[i]=val[i^1]=Xor[to[i]];
}
else if(dfn[to[i]]<dfn[x]){
val[i]=val[i^1]=getrand();
Xor[x]^=val[i],Xor[to[i]]^=val[i];
}
} inline bool ins(ll x){
for(int i=63;i>=0;i--) if(c[i]&x){
if(!a[i]){ a[i]=x; return 1;}
x^=a[i];
}
return 0;
} int main(){
srand(20010207);
c[0]=1; for(int i=1;i<64;i++) c[i]=c[i-1]+c[i-1]; n=read(),m=read();
for(int i=1,uu,vv;i<=m;i++){
uu=read(),vv=read();
add(uu,vv),add(vv,uu);
} dfs(1,0); for(Q=read();Q;memset(a,0,sizeof(a)),Q--){
K=read();
for(flag=1;K;K--){
L=read()^cnt;
if(!ins(val[L<<1])) flag=0;
}
cnt+=flag,puts(flag?"Connected":"Disconnected");
} return 0;
}

  

#include<bits/stdc++.h>
#define ll unsigned long long
using namespace std;
const int N=100005; inline int read(){
int x=0; char ch=getchar();
for(;!isdigit(ch);ch=getchar());
for(;isdigit(ch);ch=getchar()) x=x*10+ch-'0';
return x;
} int hd[N],to[N*10],ne[N*10],dc;
int num=1,n,m,Q,cnt,K,L,dfn[N];
ll val[N*10],a[66],Xor[N],c[66];
bool flag; inline void add(int x,int y){ to[++num]=y,ne[num]=hd[x],hd[x]=num;} inline ll getrand(){ return (ll)floor(rand()/(double)RAND_MAX*(double)1e19);} void dfs(int x,int fa){
dfn[x]=++dc;
for(int i=hd[x];i;i=ne[i]) if(to[i]!=fa)
if(!dfn[to[i]]){
dfs(to[i],x),Xor[x]^=Xor[to[i]];
val[i]=val[i^1]=Xor[to[i]];
}
else if(dfn[to[i]]<dfn[x]){
val[i]=val[i^1]=getrand();
Xor[x]^=val[i],Xor[to[i]]^=val[i];
}
} inline bool ins(ll x){
for(int i=63;i>=0;i--) if(c[i]&x){
if(!a[i]){ a[i]=x; return 1;}
x^=a[i];
}
return 0;
} int main(){
srand(20010207);
c[0]=1; for(int i=1;i<64;i++) c[i]=c[i-1]+c[i-1]; n=read(),m=read();
for(int i=1,uu,vv;i<=m;i++){
uu=read(),vv=read();
add(uu,vv),add(vv,uu);
} dfs(1,0); for(Q=read();Q;memset(a,0,sizeof(a)),Q--){
K=read()^cnt;
for(flag=1;K;K--){
L=read()^cnt;
if(!ins(val[L<<1])) flag=0;
}
cnt+=flag,puts(flag?"Connected":"Disconnected");
} return 0;
}

  

DZY Loves Chinese / DZY Loves Chinese II的更多相关文章

  1. tomcat chinese miscode and chinese input in IDEA

    JAVA_OPTS="$JAVA_OPTS -Djavax.servlet.request.encoding=UTF-8 -Dfile.encoding=UTF -8 -Duser.lang ...

  2. [CodeForces - 447C] C - DZY Loves Sequences

    C - DZY Loves Sequences DZY has a sequence a, consisting of n integers. We'll call a sequence ai, ai ...

  3. [CodeForces - 447B] B - DZY Loves Strings

    B - DZY Loves Strings DZY loves collecting special strings which only contain lowercase letters. For ...

  4. [CodeForces - 447A] A - DZY Loves Hash

    A - DZY Loves Hash DZY has a hash table with p buckets, numbered from 0 to p - 1. He wants to insert ...

  5. Codeforces Round #254 (Div. 1) D. DZY Loves Strings hash 暴力

    D. DZY Loves Strings 题目连接: http://codeforces.com/contest/444/problem/D Description DZY loves strings ...

  6. CodeForces 444C. DZY Loves Physics(枚举+水题)

    转载请注明出处:http://blog.csdn.net/u012860063/article/details/37509207 题目链接:http://codeforces.com/contest/ ...

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

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

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

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

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

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

随机推荐

  1. bzoj 1046 LIS

    假设我们知道以每个点开始到最后的最长上升序列,设为w[i],这样首先我们在w值中取max,如果询问的值比max大,这样显然就是无解,如果小的话,我们需要求出来字典序最小的方案. 那么对于所有i,我们肯 ...

  2. perl6中的替换

    use v6; =begin pod perl6 中的替换用S/// S有几个可选参数: :g —(长形式::global)全局匹配:替换掉所有的出现 :i —不区分大小写的匹配 :ii —(长形式: ...

  3. python面向对象进阶(下)

    一.item系列:就是把字典模拟成一个字典去操作(操作字典就用item的方式) obj[‘属性’]的方式去操作属性时触发的方法 __getitem__:obj['属性'] 时触发 __setitem_ ...

  4. notifier chain — 内核通知链【转】

    转自:http://blog.csdn.net/g_salamander/article/details/8081724 大多数内核子系统都是相互独立的,因此某个子系统可能对其它子系统产生的事件感兴趣 ...

  5. python设计模式之单例模式(二)

    上次我们简单了解了一下什么是单例模式,今天我们继续探究.上次的内容点这 python设计模式之单例模式(一) 上次们讨论的是GoF的单例设计模式,该模式是指:一个类有且只有一个对象.通常我们需要的是让 ...

  6. Smarty模板快速入门

    文件下载 1.下载地址:http://www.smarty.net/ 2.我下载的版本是3.1.27 ,将下载的文件smarty-3.1.27.zip解压出来,然后将libs文件夹的所有文件复制到你的 ...

  7. django自带的django.core.mail模块实现发邮件的功能

    django自带了一个模块,可以实现发邮件的功能.如果项目开发遇到需要发邮件进行验证的时候可以用到. 1.先要准备发件人 发邮件需要使用SMTP.SMTP是什么呢? 简单邮件传输协议(Simple M ...

  8. 辨析各类web服务器:Apache/Tomcat/Jboss/Nginx/等,还有Nodejs

    先说一下各类服务器能干啥,特点是啥,然后在区分他们的类别. (1)Apache: Apache是指Apache软件基金会的Apache HTTP Server, 它能够接收http请求,然后返回各类资 ...

  9. OpenAcc笔记——update

    program main use omp_lib use openacc implicit none real,allocatable:: v1(:) integer length, idx call ...

  10. APP线上问题收集信息整理

    常话说“软件是不能保证百分百没有bug的”,因此当我们的APP上线之后,市场的使用人员会反馈一些我们测试人员可能在测试时遗漏的问题,包括也不防会有一些需求的反馈,这些问题均由售后人员反馈整理,以一种方 ...