博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
bzoj4671: 异或图——斯特林反演
阅读量:6366 次
发布时间:2019-06-23

本文共 1360 字,大约阅读时间需要 4 分钟。

 

考虑先算一些限制少的情况

gi表示把n个点的图,划分成i个连通块的方案数

连通块之间不连通很好处理(怎么处理看下边),但是内部必须连通,就很难办了

所以再降低条件,fi表示,把n个点的图,划分成i个"连通块",保证连通块之间不会有边相连,但是内部可以不连通的方案数

fi计算方法如下:

用Bell(n)的复杂度枚举集合划分,然后相邻集合之间不能连边,

然后考虑凑出符合这个集合划分的图有多少个,异或高斯消元,xi表示第i个图选择与否,如果必须不选,等号右边就是0,否则不管。

求自由元个数

 

fi和gi的关系:

就是枚举到底是有几个连通块

 

然后斯特林反演:

虽然往上枚举,但是式子证明思路是一样的,(-1)项的指数只要保证在所谓[n=m]时候是偶数就好了

 

高斯消元也可以换成线性基

每个图一个元素。每个线性基的位表示这个图这个边有没有,并且再和这次必要的边取&

要求多少个子集xor为全0

线性基之后,2^(s-sz)即可。

 

代码:

#include
#define reg register int#define il inline#define numb (ch^'0')#define int long longusing namespace std;typedef long long ll;il void rd(int &x){ char ch;x=0;bool fl=false; while(!isdigit(ch=getchar()))(ch=='-')&&(fl=true); for(x=numb;isdigit(ch=getchar());x=x*10+numb); (fl==true)&&(x=-x);}namespace Miracle{const int M=66;const int N=66;int n,m;int edge[M][12][12];ll f[12*12];ll t[N];int ans[M];char s[N*N];ll id[N];int vis[12*12];ll Guass(int n){ memset(ans,-1,sizeof ans); memset(vis,0,sizeof vis);// for(reg i=1;i<=n;++i){// for(reg j=1;j<=m;++j){// cout<
<<" ";// }cout<<" = "<
<

 总结:

找到两个数组f,g

f范围宽松好统计,g范围严格难统计但是和答案有直接关系,

这样,只要得到f和g的关系,就可以找到答案!

 

异或下线性方程组的自由元个数:

先变成n*(n+1)的矩阵

然后高斯消元,如果某一个id找不到,那么一定是自由元了,计数器++

注意,每次找i和消除必须在全局位置,并且用一个vis标记表示是否还能动

最后削成的上三角矩阵,除了无解情况,剩下的一定有唯一解

 

转载于:https://www.cnblogs.com/Miracevin/p/10390110.html

你可能感兴趣的文章
FastCGI PHP on Windows Server 2003
查看>>
LimeSDR Getting Started Quickly | LimeSDR上手指南
查看>>
JSP标签JSTL的使用(1)--表达式操作
查看>>
SAP顾问的人脉比技术更为重要
查看>>
FI/CO PA考试试卷
查看>>
汽车介质应用非常严苛?没关系,新技术带来的高精度传感器十分适应!
查看>>
天合光能 - 用计算捕捉“光的能量”
查看>>
使用sysbench压力测试MySQL(一)(r11笔记第3天)
查看>>
css知多少(11)——position
查看>>
【Spring】定时任务详解实例-@Scheduled
查看>>
先有的资源,能看的速度看,不能看的,抽时间看。说不定那天就真的打不开了(转)...
查看>>
[20161028]rman与filesperset=1.txt
查看>>
哪些领域适合开发微信小程序
查看>>
谁说数据库防火墙风险大?可能你还不知道应用关联防护
查看>>
ASP.NET Core应用针对静态文件请求的处理[2]: 条件请求与区间请求
查看>>
怎样做一个企业?尤其是在这个互联网时代
查看>>
DVNA:Node.js打造的开源攻防平台
查看>>
17个案例带你3分钟搞定Linux正则表达式
查看>>
Java 8 比较器:如何对 List 排序
查看>>
苹果是否步思科后尘折戟中国
查看>>