http://uoj.ac/problem/37

题解

题目是让我们求出有多少个边集可以使这张图强连通。

先补集转化一下,求这张图不强连通的方案数。

我们考虑这样的图缩完点之后的情况,既然不强连通,那么它就是个\(DAG\)。

回顾一下有向图\(DAG\)计数的方法。

每次新加入一层入度为\(0\)的点,向之前的点连边。但这时我们不能保证我们枚举的点就是全部入度为\(0\)的,所以我们还需要容斥。

\[f[S]=\sum_{T\subset S}(-1)^{|T|}f[S-T]2^{edge(S,S-T)}
\]

再次观察到容斥系数之和点数的奇偶性有关,因为此时我们的每个点已经是一个强连通分量了。

所以我们设\(deg[s]\)表示\(s\)集合是一个\(DAG\),如果求出了这个数组,那么我们用全集减去它就是答案了。

我们再设\(D[s]\)表示\(s\)集合被划分为奇数个强连通分量的方案数,\(S[s]\)表示划分为偶数个强连通分量的方案数。

转移:

\[dag[S]=\sum_{T\subset S}(D[S]-S[S])*2^{edge(T,S-T)+edge(S-T,S-T)}
\]

最后加上自己连自己的方案数是因为我们的容斥系数已经弄好了,只需要让\(S-T\)缩完点之后成为一个\(DAG\)就行了,所以合法的边集是全集。

我们最后的答案\(f[s]\)表示\(s\)集合强连通的方案数,\(D\)和\(S\)的转移有:

\[D[S]=\sum_{T\subset S}f[T]*S[S-T]
\]

\[S[S]=\sum_{T\subset S}f[T]*D[S-T]
\]

代码

#include<bits/stdc++.h>
#define N 16
#define M 225
using namespace std;
typedef long long ll;
const int mod=1e9+7;
int n,m;
ll D[1<<N],S[1<<N],ci[N*N],f[1<<N];
bitset<M>in[1<<N],out[1<<N];
inline void MOD(ll &x){x=x>=mod?x-mod:x;}
inline ll rd(){
ll x=0;char c=getchar();bool f=0;
while(!isdigit(c)){if(c=='-')f=1;c=getchar();}
while(isdigit(c)){x=(x<<1)+(x<<3)+(c^48);c=getchar();}
return f?-x:x;
}
inline int calc(int s,int t){return (out[s]&in[t]).count();}
int main(){
n=rd();m=rd();
int u,v;
int maxn=(1<<n)-1;
ci[0]=1;
for(int i=1;i<=n*n;++i)ci[i]=ci[i-1]*2%mod;
for(int i=1;i<=m;++i){
u=rd();v=rd();
for(int j=1;j<=maxn;++j){
if(j&(1<<u-1))out[j][i]=1;
if(j&(1<<v-1))in[j][i]=1;
}
}
S[0]=1;
for(int i=1;i<=maxn;++i){
f[i]=ci[calc(i,i)];
for(int s=(i-1)&i;s;s=(s-1)&i){
MOD(f[i]=(f[i]-(D[s]-S[s])*ci[calc(s,i-s)+calc(i-s,i-s)]%mod+mod));
if((s&(i&-i))==0)continue;
MOD(D[i]+=f[s]*S[i-s]%mod);
MOD(S[i]+=f[s]*D[i-s]%mod);
}
MOD(f[i]=(f[i]-(D[i]-S[i]))%mod+mod);
MOD(D[i]+=f[i]);
}
cout<<f[maxn];
return 0;
}

UOJ37. 【清华集训2014】主旋律的更多相关文章

  1. 【uoj#37/bzoj3812】[清华集训2014]主旋律 状压dp+容斥原理

    题目描述 求一张有向图的强连通生成子图的数目对 $10^9+7$ 取模的结果. 题解 状压dp+容斥原理 设 $f[i]$ 表示点集 $i$ 强连通生成子图的数目,容易想到使用总方案数 $2^{sum ...

  2. BZOJ3812 清华集训2014 主旋律

    直接求出强联通生成子图的数量较难,不妨用所有生成子图的数量减去非强联通的. 非强联通生成子图在所点后满足编号最小的点所在的强联通分量不是全集. 由于$n$很小,我们可以考虑状态压缩. 对于点集$S$, ...

  3. 【UOJ#37】 [清华集训2014] 主旋律

    题目链接 题目描述 给定一张强联通图,求有多少种边的存在情况满足图依然强联通. \(n\leq15\) Sol 首先正难则反,考虑用总数减去不强联通的. 考虑一张不强联通的图,缩点后一定是一个 DAG ...

  4. uoj 41 【清华集训2014】矩阵变换 婚姻稳定问题

    [清华集训2014]矩阵变换 Time Limit: 20 Sec  Memory Limit: 256 MB 题目连接 http://uoj.ac/problem/41 Description 给出 ...

  5. AC日记——【清华集训2014】奇数国 uoj 38

    #38. [清华集训2014]奇数国 思路: 题目中的number与product不想冲: 即为number与product互素: 所以,求phi(product)即可: 除一个数等同于在模的意义下乘 ...

  6. UOJ#46. 【清华集训2014】玄学

    传送门 分析 清华集训真的不是人做的啊嘤嘤嘤 我们可以考虑按操作时间把每个操作存进线段树里 如果现在点x正好使一个整块区间的右端点则更新代表这个区间的点 我们不难发现一个区间会因为不同的操作被分成若干 ...

  7. 清华集训2014 sum

    清华集训2014sum 求\[∑_{i=1}^{n}(-1)^{⌊i√r⌋}\] 多组询问,\(n\leq 10^9,t\leq 10^4, r\leq 10^4\). 吼题解啊 具体已经讲得很详细了 ...

  8. 清华集训2014 day1 task2 主旋律

    题目 这可算是一道非常好的关于容斥原理的题了. 算法 好吧,这题我毫无思路,直接给正解. 首先,问题的正面不容易求,那么就求反面吧: 有多少种添加边的方案,使得这个图是DAG图(这里及以下所说的DAG ...

  9. UOJ#37. 【清华集训2014】主旋律

    题目大意: 传送门 题解: 神题……Orz. 首先正难则反. 设$f_S$表示选取点集状态为s时,这部分图可以构成非强联通图的方案数. 设$p_{S,i}$表示点集s缩点后有i个入度为0点的方案数,保 ...

随机推荐

  1. python控制流-名词解释

    一.控制流的元素 控制流语句的开始部分通常是“条件”,接下来是一个代码块,称为“子句”. 二.控制流的条件 条件为了判断下一步如何进行,从而求布尔值的表达式.几乎所有的控制流语句都使用条件. 三.代码 ...

  2. [Web 前端] 030 ajax 是什么

    AJAX 是什么 1. AJAX 是一种"艺术" 简单地说 AJAX 是在不重新加载整个页面的情况下与服务器交换数据并更新部分网页的艺术 网上是这样说的 AJAX 指异步 Java ...

  3. urllib库认证,代理,cookie

    认证,代理,cookie 1from urllib.request import HTTPBasicAuthHandler, HTTPPasswordMgrWithDefaultRealm, buil ...

  4. poj-1236.network of schools(强连通分量 + 图的入度出度)

    Network of Schools Time Limit: 1000MS   Memory Limit: 10000K Total Submissions: 27121   Accepted: 10 ...

  5. HTTP/2 最新漏洞,直指 Kubernetes!

    Java技术栈 www.javastack.cn 优秀的Java技术公众号 在这个数据.应用横行的时代,漏洞的出现早已屡见不鲜.在尚未造成大面积危害之前,我们该如何做好防御措施?或许从过往经常发生漏洞 ...

  6. 概率与期望dp相关

    概率与期望dp 概率 某个事件A发生的可能性的大小,称之为事件A的概率,记作P(A). 假设某事的所有可能结果有n种,每种结果都是等概率,事件A涵盖其中的m种,那么P(A)=m/n. 例如投掷一枚骰子 ...

  7. homestead修改php版本

    登录后 如果之前没有设置过root密码 sudo passwd root 以root 权限执行如下命令,选择对应php版本 # 查看所有 php 版本和当前版本 update-alternatives ...

  8. virtualenvwrapper安装和使用

    virtualenvwrapper安装和使用步骤: 1.安装: *nix上安装的命令: pip install virtualenvwrapper windows上安装的命令: pip install ...

  9. 4-2如何判断字符串a是否以字符串b开头或结尾

    1.相关介绍 1.1修改文件权限和查看文件权限 在windows平台实验时 os.chmod()无法将文件权限修改为可执行,暂不深究如何实现.在linux平台进行测试. (1)创建三个文件 pytho ...

  10. P2505 [HAOI2012]道路

    传送门 统计每条边被最短路经过几次,点数不大,考虑计算以每个点为起点时对其他边的贡献 对于某个点 $S$ 为起点的贡献,首先跑一遍最短路,建出最短路的 $DAG$ 考虑 $DAG$ 上的某条边被以 $ ...