BZOJ 3812 : 主旋律
非常神仙的状压DP+容斥原理。
首先,给出一个状压方程:$f_S$表示点集为$S$的情况下,整个点集构成强连通图的方案数。
这个DP方程还是比较容易想到的,但是没有办法正常转移,考虑通过容斥原理进行转移。
对于一个点集,它无法构成强连通分量的方案,就是我们选择一个出度为$0$的强连通分量,这个强连通分量并不包含整体的方案,就是无法构成的方案数,也就是缩点后的图是一个至少两个节点的DAG。
那么,我们可以钦定一个点集$j,j\subset S$作为出度为$0$的强连通分量,那么可以得到,这样其他的不是从这个点集连向其他点集的边是随意选取的,也就是$2^p$种方案。
但是由于我们不知道$S-j$的部分中有没有出现出度为$0$的强连通分量,如果出现,那么就重复计算了。
所以考虑容斥,$t_i$表示$i$点集构成点数大于1的DAG的方案数,$t_S=\sum\limits_{j\subseteq S,j\ne 0}{(-1)^{|j|-1}\times 2^{way_{i-j,j}}}\times t_{i-j}$,其中$way_{j,i-j}$表示$i-j$点集向$j$点集链接的边,$|j|$表示选择的强连通分量集的强连通分量数量。
上面的式子应该会很好理解,就不多解释了,那么根据上面的式子,我们提出一个建设性的想法,$g_i$表示$i$的点集中,构成奇数个互不连通强连通分量-构成偶数个互不连通强连通分量的方案数,也就是说在状态中直接包含容斥系数,那么可以给出方程:$g_S=f_S-\sum\limits_{j\subseteq S,u\in j}g_{S-j}\times f_j$
这个式子的正确性关键在于$g_S$构成的强连通分量是互不连通(因为出度全部为$0$)的,所以这样转移显然是正确的。
那么接下来考虑$f_S$如何更新。
同样,我们回到上面的式子,$t_S$可以表达为:$t_S=\sum\limits_{j\subset i,j\ne 0}g_j\times 2^{sum_S-w_j}$,$w_j$表示$j$连向$S$的边数。
然后,$f_S=2^{sum_S}-t_S$
然后我们就解决这道题啦!撒花撒花✿✿ヽ(°▽°)ノ✿
建议搭配下面文档食用
https://files-cdn.cnblogs.com/files/Winniechen/BZOJ3812.pdf
#include <cstdio>
#include <algorithm>
#include <cmath>
#include <cstring>
#include <cstdlib>
#include <queue>
#include <iostream>
#include <bitset>
using namespace std;
#define N (1<<15)+20
#define ll long long
#define mod 1000000007
int f[N],g[N],cnt[N],in[N],out[N],n,m,b[N],w[N],sum[N];
void dfs(int i,int j)
{
if(i&(j-1))dfs(i,i&(j-1));
w[j]=w[j-(j&-j)]+cnt[in[j&-j]&i];
}
int main()
{
scanf("%d%d",&n,&m);b[0]=1;
for(int i=1,x,y;i<=m;i++)
{
scanf("%d%d",&x,&y);x--,y--;
in[1<<x]|=1<<y,out[1<<y]|=1<<x;
b[i]=(b[i-1]<<1)%mod;
}
for(int S=1;S<1<<n;S++)
{
int x=S&-S,s=S^x;cnt[S]=cnt[s]+1;sum[S]=sum[s]+cnt[in[x]&S]+cnt[out[x]&S];
dfs(S,S);f[S]=b[sum[S]];
for(int j=s;j;j=s&(j-1))g[S]=(g[S]-(ll)f[S^j]*g[j])%mod;
for(int j=S;j;j=S&(j-1))f[S]=(f[S]-(ll)g[j]*b[sum[S]-w[j]])%mod;
g[S]=(g[S]+f[S])%mod;
}
printf("%d\n",(f[(1<<n)-1]+mod)%mod);
}
BZOJ 3812 : 主旋律的更多相关文章
- BZOJ 3812 主旋律 (状压DP+容斥) + NOIP模拟赛 巨神兵(obelisk)(状压DP)
这道题跟另一道题很像,先看看那道题吧 巨神兵(obelisk) 题面 欧贝利斯克的巨神兵很喜欢有向图,有一天他找到了一张nnn个点mmm条边的有向图.欧贝利斯克认为一个没有环的有向图是优美的,请问这张 ...
- bzoj 3812: 主旋律 [容斥原理 状压DP]
3812: 主旋律 题意:一张有向图,求它的生成子图是强连通图的个数.\(n \le 15\) 先说一个比较暴力的做法. 终于知道n个点图的是DAG的生成子图个数怎么求了. 暴力枚举哪些点是一个scc ...
- BZOJ 3812主旋律
求一个图中强联通图的个数. 一看就是容斥啦,但这种二进制高端操作还是学习一下Candy?dalao 注释在代码里 好久没更了... #include<bits/stdc++.h> usin ...
- 【BZOJ 3812】 3812: 主旋律 (容斥原理**)
3812: 主旋律 Time Limit: 10 Sec Memory Limit: 256 MBSubmit: 235 Solved: 196 Description 响应主旋律的号召,大家决定 ...
- Solution -「BZOJ 3812」主旋律
\(\mathcal{Description}\) Link. 给定含 \(n\) 个点 \(m\) 条边的简单有向图 \(G=(V,E)\),求 \(H=(V,E'\subseteq E)\ ...
- bzoj AC倒序
Search GO 说明:输入题号直接进入相应题目,如需搜索含数字的题目,请在关键词前加单引号 Problem ID Title Source AC Submit Y 1000 A+B Problem ...
- BZOJ 2127: happiness [最小割]
2127: happiness Time Limit: 51 Sec Memory Limit: 259 MBSubmit: 1815 Solved: 878[Submit][Status][Di ...
- BZOJ 3275: Number
3275: Number Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 874 Solved: 371[Submit][Status][Discus ...
- BZOJ 2879: [Noi2012]美食节
2879: [Noi2012]美食节 Time Limit: 10 Sec Memory Limit: 512 MBSubmit: 1834 Solved: 969[Submit][Status] ...
随机推荐
- Ajax发送POST请求对数据的封装
Ajax发送POST请求把数据到后端后,后端收到数据并解析出来 示列一: Ajax发送请求,这里主要是发送一个数组的数据类型到后端,如果没有先把数组进行格式化成字符串的话,后端就收了就是一个字符串类型 ...
- drupal7创建自定义的panels布局
很简单,在主题的 *.info文件中添加一句代码: 这一句很简单,但也很重要,没有这一句,就没在panels的配置界面去显示自定义的布局 plugins[panels][layouts] = layo ...
- 微信小程序开发--宽为百分百,页面仍可左右滑动
这段时间小程序开发时,很多时候,希望内容充满整个屏幕(高度.宽度100%),如下图 但是在设置 .followrecords-container{width:100%;} 后发现 手机在横向上虽然页面 ...
- Android 经典欧美小游戏 guess who
本来是要做iOS开发的,因为一些世事无常和机缘巧合与测试工作还有安卓系统结下了不解之缘,前不久找到了guess who 源码,又加入了一些自己的元素最终完成了这个简单的小游戏. <?xml ve ...
- Centos 7 安装GNOME桌面环境
第一步:列出可安装的桌面环境 [root@local ~]# yum grouplist 第二步:安装GNOME及相应桌面管理工具 [root@local ~]# yum group info &qu ...
- Python图像识别(聚类)
# -*- coding: utf-8 -*- """ Created on Fri Sep 21 15:37:26 2018 @author: zhen "& ...
- 如何在 Azure 中标记 Windows 虚拟机
本文介绍在 Azure 中通过 Azure 资源管理器标记 Windows 虚拟机的不同方式.标记是用户定义的键/值对,可直接放置在资源或资源组中.针对每个资源和资源组,Azure 当前支持最多 15 ...
- Automation Script For Percona Xtrabackup FULL/Incremental
This is my first post in 2019, and Im starting with a MySQL solution. In MySQL world, implementing a ...
- centos7 修改中文字符集
CentOS 7字符集的问题与6有点区别,会出现下面问题,查看是中文,vi进入就变成乱码了 生产中修改配置文件 [root@ce1d2002a999 ~]# cat /etc/locale.con ...
- pip 设置国内源
最近使用 pip 安装包,动辄十几 k 甚至几 k 的下载速度,确实让人安装的时候心情十分不好.所以还是要给 pip 换一个国内的源.可以显著的提升安装速度.有更多的时间来研究算法. 下面,列一下收集 ...