【bzoj 4671】 异或图
神仙题啊神仙题
显然这个东西一脸不可求的样子啊,这种东西我们显然需要搞一个容斥什么的
于是设\(g_i\)表示至少存在\(i\)个联通块(联通块内部的边没有要求,联通块和联通块之间不存在边)的方案数,\(f_i\)表示恰有\(i\)个联通块
有
\]
即我们对于那些联通块个数多于\(x\)个的情况,可以把这\(i\)个联通快分成\(k\)组,每一组作为一个新的“联通块”,于是后面那个是一个第二类斯特林数
于是根据斯特林反演,有
\]
对于这道题我们要求的就是\(f_1\)
\]
现在要做的就是求\(g_i\)了
我们注意到这张图的点数很少,我们甚至可以爆搜一下每个点分到哪一个集合里去,我们就可以扫一遍每一张图,对于一条连接两个不同集合的边,我们把这条边用二进制状态存一下,现在只需要求出有多少个子集异或和为\(0\)就好了
这个问题可以用线性基来解决,结论就是如果有\(x\)个元素不能插入线性基,那么异或和为\(0\)的子集数量就是\(2^x\)个
这个可以这样理解啊,我们把不能插入线性基的元素拿出来,这些元素构成的子集个数是\(2^x\)个,显然\(2^x\)个子集也都能被线性基表示出来,我们把线性基里表示这些子集的那些元素和这些子集异或,就得到了\(2^x\)个异或和为\(0\)的子集,由于线性基里没有任何一个子集异或和为\(0\),于是总共就是\(2^x\)个
这样对于每一个不能插入线性基的元素都有两种选择,于是子集个数是\(2^x\)种
代码
#include<cstdio>
#include<cstring>
#define re register
#define LL long long
int m,n,len,t;LL ans,cnt;
char S[1005];
LL fac[15],pw[105],lb[50],g[15],b[66];
int a[15],vis[66][15][15];
inline int ins(LL x) {
for(re int i=t-1;i>=0;--i)
if(x>>i&1) {
if(!lb[i]) {lb[i]=x;return 1;}
x^=lb[i];
}
return 0;
}
void dfs(int x,int now) {
if(x==n+1) {
t=0;memset(lb,0,sizeof(lb));
for(re int k=1;k<=m;k++) {
b[k]=t=0;
for(re int i=1;i<=n;i++)
for(re int j=i+1;j<=n;j++)
if(a[i]!=a[j]) b[k]|=(1ll*vis[k][i][j]<<t),t++;
}
int tot=0;
for(re int k=1;k<=m;k++) if(!ins(b[k])) ++tot;
g[now]+=pw[tot];
return;
}
for(re int i=1;i<=now;i++) a[x]=i,dfs(x+1,now);
a[x]=now+1;dfs(x+1,now+1);
}
int main() {
scanf("%d",&m);
for(re int k=1;k<=m;k++) {
scanf("%s",S+1);len=strlen(S+1);
if(!n) {n=1;while(n*(n-1)/2!=len) n++;}
int now=1;
for(re int i=1;i<=n;i++)
for(re int j=i+1;j<=n;j++)
vis[k][i][j]=S[now]-'0',now++;
}
fac[0]=1;pw[0]=1;
for(re int i=1;i<=m;i++) pw[i]=pw[i-1]+pw[i-1];
for(re int i=1;i<=n;i++) fac[i]=1ll*fac[i-1]*i;
dfs(1,0);
for(re int i=1;i<=n;i++) ans+=1ll*((i&1)?1:-1)*fac[i-1]*g[i];
printf("%lld\n",ans);
return 0;
}
【bzoj 4671】 异或图的更多相关文章
- BZOJ 4671 异或图 | 线性基 容斥 DFS
题面 Description 定义两个结点数相同的图 G1 与图 G2 的异或为一个新的图 G, 其中如果 (u, v) 在 G1 与 G2 中的出现次数之和为 1, 那么边 (u, v) 在 G 中 ...
- bzoj 4671 异或图——容斥+斯特林反演+线性基
题目:https://www.lydsy.com/JudgeOnline/problem.php?id=4671 考虑计算不是连通图的方案,乘上容斥系数来进行容斥. 可以枚举子集划分(复杂度是O(Be ...
- bzoj 4671 异或图 —— 容斥+斯特林反演+线性基
题目:https://www.lydsy.com/JudgeOnline/problem.php?id=4671 首先,考虑容斥,就是设 \( t[i] \) 表示至少有 \( i \) 个连通块的方 ...
- [BZOJ 4671]异或图
Description 题库链接 给定 \(s\) 个结点数相同且为 \(n\) 的图 \(G_1\sim G_s\) ,设 \(S = \{G_1, G_2,\cdots , G_s\}\) ,问 ...
- 【BZOJ】4671: 异或图
题解 写完之后开始TTTTTTT--懵逼 这道题我们考虑一个东西叫容斥系数啊>< 这个是什么东西呢 也就是\(\sum_{i = 1}^{m}\binom{m}{i}f_{i} = [m ...
- 【BZOJ4671】异或图(斯特林反演)
[BZOJ4671]异或图(斯特林反演) 题面 BZOJ Description 定义两个结点数相同的图 G1 与图 G2 的异或为一个新的图 G, 其中如果 (u, v) 在 G1 与 G2 中的出 ...
- bzoj4671 异或图(斯特林反演,线性基)
bzoj4671 异或图(斯特林反演,线性基) 祭奠天国的bzoj. 题解时间 首先考虑类似于容斥的东西. 设 $ f_{ i } $ 为至少有 $ i $ 个连通块的方案数, $ g_{ i } $ ...
- bzoj4671: 异或图——斯特林反演
[BZOJ4671]异或图 - xjr01 - 博客园 考虑先算一些限制少的情况 gi表示把n个点的图,划分成i个连通块的方案数 连通块之间不连通很好处理(怎么处理看下边),但是内部必须连通,就很难办 ...
- 【XSY2701】异或图 线性基 容斥原理
题目描述 定义两个图\(G_1\)与\(G_2\)的异或图为一个图\(G\),其中图\(G\)的每条边在\(G_1\)与\(G_2\)中出现次数和为\(1\). 给你\(m\)个图,问你这\(m\)个 ...
- bzoj4671: 异或图
bzoj4671: 异或图 Description 定义两个结点数相同的图 G1 与图 G2 的异或为一个新的图 G, 其中如果 (u, v) 在 G1 与 G2 中的出现次数之和为 1, 那么边 ( ...
随机推荐
- MapReduce1.0的缺陷
- Python基础知识之5——函数基础
函数 函数是一个独立且封闭完成特定功能的代码块,可以在任何地方被调用.Python内置了很多函数,我们可以直接调用,使用的时候,先查询下Python的官方文档即可: http://docs.pytho ...
- AOP与IOC的概念(即spring的核心)
a) IOC:Spring是开源框架,使用框架可以使我们减少工作量,提高工作效率并且它是分层结构,即相对应的层处理对应的业务逻辑,减少代码的耦合度.而spring的核心是IOC控制反转和AOP面向切面 ...
- CSIC_716_20191113【装饰器进阶以及迭代器】
装饰器的进阶主要包含叠加装饰器和有参装饰器 叠加装饰器:在一个被装饰的对象中,添加多个装饰器. 为什么要用叠加装饰器的原因: -每一个新的功能都应该写一个新的装饰器,否则会导致,代码冗余,结构不 ...
- [转]spring入门(六)【springMVC中各数据源配置】
在使用spring进行javaWeb开发的过程中,需要和数据库进行数据交换,为此要经常获取数据库连接,使用JDBC的方式获取数据库连接,使用完毕之后再释放连接,这种过程对系统资源的消耗无疑是很大的,这 ...
- hadoop快照管理
快照相当于对目录做备份,并不会复制所有文件,而是记录文件的变化命令用法 ()hdfs dfsadmin -allowSnapshot 路径 (开启指定目录的快照功能) ()hdfs dfsadmin ...
- Kmeans算法实现
下面的demo是根据kmeans算法原理实现的demo,使用到的数据是kmeans.txt 1.658985 4.285136 -3.453687 3.424321 4.838138 -1.15153 ...
- hibernate_02_hibernate的入门
1.什么是Hibernate框架? Hibernate是一种ORM框架,全称为 Object_Relative DateBase-Mapping,在Java对象与关系数据库之间建立某种映射,以实现直接 ...
- C# ObservableCollection集合排序
版权声明:本文为博主原创文章,未经博主允许不得转载. https://blog.csdn.net/BYH371256/article/details/83346807注意:ObservableColl ...
- elasticsearch的索引清理
curl -XDELETE 'http://127.0.0.1:9200/winlogbeat-6.0.0-2017.07.*' 脚本加api删除(推荐) cat es-index-clear.sh ...