[Poetize I]黑魔法师之门

描述 Description

  applepi被囚禁的地点只有一扇门,当地 人称它为“黑魔法师之门”。这扇门上画着一张无向无权图,而打开这扇门的密码就是图中【每个点的度数大于零且都是偶数】的子图的个数对 1000000009取模的值。此处子图 (V, E) 定义为:点集V和边集E都是原图的任意子集,其中E中的边的端点都在V中。
  但是Vani认为这样的密码过于简单,因此门上的图是动态的。起初图中只有N个顶点而没有边。Vani建造的门控系统共操作M次,每次往图中添加一条边。你必须在每次操作后都填写正确的密码,才能够打开黑魔法师的牢狱,去拯救伟大的领袖applepi。

题解:

题意很清楚,但是感觉很神。。。
刚开始一直在想如何构造,发现太复杂
然后查题解发现只有要当前两点在同一连通块里,ans*=2,最后输出ans-1
表示不理解,就没写。
昨天翻到了lyd的题解
他引入了一个叫 元环 的东西,然后证明答案就是 2^元环的个数
我表示对元环的概念不理解,然后发现如果把整张图画在一张平面上,那么 元环 就是 区域!
然后为什么加入一条边连接两个已在同一连通块里的时候区域数+1呢?
这使我想到了欧拉公式:
V+F-E=2
其中 V表顶点数,F表区域数,E表边数
加入一条边后E++,V不变,所以F要++
至于为什么答案就是2^区域-1
出题人说:
每一个区域有选或不选2种情况,若选就把这个区域的边界的边的选择次数++,最后把所有选择次数为奇数的边选出来救能够成答案。可以证明这是不重不漏的。
至于为什么不重不漏,我还没有思考出结果。
挖坑待填。。。
代码:

 1 #include<cstdio>
 2
 3 #include<cstdlib>
 4
 5 #include<cmath>
 6
 7 #include<cstring>
 8
 9 #include<algorithm>
10
11 #include<iostream>
12
13 #include<vector>
14
15 #include<map>
16
17 #include<set>
18
19 #include<queue>
20
21 #include<string>
22
23 #define inf 1000000000
24
25 #define maxn 250000
26
27 #define maxm 500+100
28
29 #define eps 1e-10
30
31 #define ll long long
32
33 #define pa pair<int,int>
34
35 #define for0(i,n) for(int i=0;i<=(n);i++)
36
37 #define for1(i,n) for(int i=1;i<=(n);i++)
38
39 #define for2(i,x,y) for(int i=(x);i<=(y);i++)
40
41 #define for3(i,x,y) for(int i=(x);i>=(y);i--)
42
43 #define mod 1000000009
44
45 using namespace std;
46
47 inline int read()
48
49 {
50
51     int x=0,f=1;char ch=getchar();
52
53     while(ch<‘0‘||ch>‘9‘){if(ch==‘-‘)f=-1;ch=getchar();}
54
55     while(ch>=‘0‘&&ch<=‘9‘){x=10*x+ch-‘0‘;ch=getchar();}
56
57     return x*f;
58
59 }
60 int n,m,fa[maxn];
61 inline int find(int x){return fa[x]==x?x:fa[x]=find(fa[x]);}
62
63 int main()
64
65 {
66
67     freopen("input.txt","r",stdin);
68
69     freopen("output.txt","w",stdout);
70
71     n=read();m=read();
72     for1(i,n)fa[i]=i;
73     int ans=1;
74     for1(i,m)
75     {
76         int x=find(read()),y=find(read());
77         if(x!=y)fa[x]=y;else ans<<=1,ans%=mod;
78         printf("%d\n",(ans-1+mod)%mod);
79     }
80
81     return 0;
82
83 }

时间: 2024-08-10 02:43:13

[Poetize I]黑魔法师之门的相关文章

CODEVS1995 || TYVJ1863 黑魔法师之门

P1863 [Poetize I]黑魔法师之门 时间: 1000ms / 空间: 131072KiB / Java类名: Main 背景 经过了16个工作日的紧张忙碌,未来的人类终于收集到了足够的能源.然而在与Violet星球的战争中,由于Z副官的愚蠢,地球的领袖applepi被邪恶的黑魔法师Vani囚禁在了Violet星球.为了重启Nescafé这一宏伟的科技工程,人类派出了一支由XLk.Poet_shy和lydrainbowcat三人组成的精英队伍,穿越时空隧道,去往Violet星球拯救领袖

黑魔法师之门

并查集 黑魔法师之门 试题描述   经过了16 个工作日的紧张忙碌,未来的人类终于收集到了足够的能源.然而在与Violet星球的战争中,由于Z 副官的愚蠢,地球的领袖applepi 被邪恶的黑魔法师Vani 囚禁在了Violet 星球.为了重启Nescafé这一宏伟的科技工程,人类派出了一支由XLk.Poet_shy 和lydrainbowcat 三人组成的精英队伍,穿越时空隧道,去往Violet 星球拯救领袖applepi.applepi 被囚禁的地点只有一扇门,当地人称它为“黑魔法师之门”.

刷过一题之黑魔法师之门

经过了16 个工作日的紧张忙碌,未来的人类终于收集到了足够的能源.然而在与Violet星球的战争中,由于Z 副官的愚蠢,地球的领袖applepi 被邪恶的黑魔法师Vani 囚禁在了Violet 星球.为了重启Nescafé这一宏伟的科技工程,人类派出了一支由XLk.Poet_shy 和lydrainbowcat 三人组成的精英队伍,穿越时空隧道,去往Violet 星球拯救领袖applepi.applepi 被囚禁的地点只有一扇门,当地人称它为“黑魔法师之门”.这扇门上画着一张无向无权图,而打开这

入门OJ 4192: [Noip模拟题]黑魔法师之门

题目 Description applepi被囚禁的地点只有一扇门,当地人称它为"黑魔法师之门".这扇门上画着一张无向无权图,而打开这扇门的密码就是图中[每个点的度数大于零且都是偶数]的子图的个数对1000000009取模的值.此处子图 (V, E) 定义为:点集V和边集E都是原图的任意子集,其中E中的边的端点都在V中.但是Vani认为这样的密码过于简单,因此门上的图是动态的.起初图中只有N个顶点而没有边.Vani建造的门控系统共操作M次,每次往图中添加一条边.你必须在每次操作后都填写

黑魔法师之门 (magician)-并查集

题目 经过了 16 个工作日的紧张忙碌,未来的人类终于收集到了足够的能源.然而在与 Violet 星球的战争中,由于 Z 副官的愚蠢,地球的领袖 applepi 被邪恶的黑魔法师 Vani 囚禁在了 Violet 星球.为了重启 Nescafé这一宏伟的科技工程,人类派出了一支由 XLk.Poet_shy 和 lydrainbowcat 三人组成的精英队伍,穿越时空隧道,去往 Violet 星球拯救领袖 applepi. applepi 被囚禁的地点只有一扇门,当地人称它为“黑魔法师之门”.这扇

[codevs 1995]黑魔法师之门(并查集)

题目:http://codevs.cn/problem/1995/ 分析:脑补一下满足题目要求的子图肯定就是环……于是题目就变成了不断加边求环的个数.看起来有点麻烦……但是环的实质是几个小环组合起来的……所以我们只需要知道最基础的环的个数就行了,根据二项式定理那么就是2^(最基础的环的个数)-1.还是不好做啊!!!!!! 没关系……并查集来了…… 假设对于第i-1操作后,最终答案为ans,那么对于第i次操作,分为两种情况 ①加入这条边后,没有出现新环,那么说明对结果无影响,结果还是ans ②加入

2014082701黑魔法师之门(C++)

#include<iostream>#define p 1000000009using namespace std;int read() { int f=0; char x;x=getchar(); while(x<'0'||x>'9') x=getchar(); while(x>='0'&&x<='9') { f=f*10+x-'0'; x=getchar(); } return f;}int fa[200001];int find(int x){re

SEO黑页以及门页框架和JS跳转实现方法

在去年大家还在针对第三方博客狂轰乱炸,比如:webs.com.blogspot.com.weebly.com主要是因为本身博客平台的权重,再就是低廉的成本,主需要注册,没有域名和服务器的投入.排名也非常好上,实现这种门页的方法也是五花八门,比如:利用JS设置从搜索引擎来路直接跳转的,嵌入框架的,调用主站代码的. 但是今天google几次算法的调整之后,这些第三方平台的权重被削弱了,也很少有这样的平台会有很好的排名,以往有的一些中上词,几乎占满前三页.面对这种情况外贸SEOer们怎么办?不做门页了

大神刷题表

9月27日 后缀数组:[wikioi3160]最长公共子串 dp:NOIP2001统计单词个数 后缀自动机:[spoj1812]Longest Common Substring II [wikioi3160]最长公共子串 [spoj7258]Lexicographical Substring Search 扫描线+set:[poj2932]Coneology 扫描线+set+树上删边游戏:[FJOI2013]圆形游戏 结论:[bzoj3706][FJ2014集训]反色刷 最小环:[poj1734