题目:https://www.lydsy.com/JudgeOnline/problem.php?id=2560

转载:


很明显的状压dp 
一开始写的dp可能会出现重复统计的情况 而且难以去重 
假设 一个状态s的随意连边集合是A; 
那么 A应该是 全部合法的方案(Ans)+sigma(某一部分合法(即某一部分是连通图)的方案*其他任意连边的方案); 
那么可以把最终答案设置为f[i], 随意连边(也可以完全连边)设置成g[i]; 
先定一个基准点 x 和基准点相连的都是合法的, 其余集合 t=s^(1<<(x-1))可以随便连; 
f[i]=g[i]-sigma((t的所有子集i)f[i]*g[s^i]); 
为什么一个是f 一个是g 这样其实是要保证不重不漏


而且必须特别注意划分点一定是连通部分的,因为单个的点也算连通,但是这个“连通”会和随便连的方案混在一起(比如此时没有一个点相互连通的情况);

但是确实有这样的情况,所以如果把划分点作为连通部分,那么这种方案只被算了一次,不会多算;

而若把划分点作为随便连部分,那么其他每个点都会有一次单独连通情况,就会多算了。

代码如下:

#include<iostream>
#include<cstdio>
#include<cstring>
using namespace std;
typedef long long ll;
ll const mod=;
ll n,a[][],f[<<],g[<<];
int main()
{
scanf("%d",&n);
for(int i=;i<=n;i++)
for(int j=;j<=n;j++)
scanf("%d",&a[i][j]);
int m=(<<n)-;
for(int s=;s<=m;s++)
{
g[s]=;
for(int i=;i<=n;i++) if(s&(<<(i-)))
for(int j=i+;j<=n;j++) if(s&(<<(j-)))
(g[s]*=(a[i][j]+))%=mod;
f[s]=g[s];
int nw;
for(nw=n-;;nw--)
if(s&(<<nw))break;
nw=(s^(<<nw));//去掉一个划分点
for(int k=nw;k;k=((k-)&nw))//枚举nw的子集
((f[s]-=g[k]*f[s^k])+=mod)%=mod;//f和g别反
}
printf("%lld",f[m]);
return ;
}

最新文章

  1. python __getitem__, __setitem__ 实现属性的索引式存取
  2. SAX与DOM
  3. 统计图表类型选择应用总结&amp;表数据挖掘方法及应用
  4. Kali Linux 秘籍/Web渗透秘籍/无线渗透入门
  5. C# 消息队列
  6. 已知2个一维数组:a[]={3,4,5,6,7},b[]={1,2,3,4,5,6,7};把数组a与数组b 对应的元素乘积再赋值给数组b,如:b[2]=a[2]*b[2];最后输出数组b的元素。
  7. 想当站长请立即使用Orchard
  8. paper 4:支持向量机系列一: Maximum Margin Classifier —— 支持向量机简介。
  9. Windows 7/8 创建WIFI热点
  10. code blocks 快捷键
  11. java程序连接MongoDB副本集测试
  12. CSS实现背景透明而背景上的文字图片不透明
  13. Spring框架学习之依赖注入
  14. sublime自动保存(失去焦点自动保存)
  15. Robots.txt - 禁止爬虫
  16. 201621123031 《Java程序设计》第9周学习总结
  17. 滚动 docker 中的 nginx 日志
  18. React 思维索引
  19. CF1140E Palindrome-less Arrays
  20. mybatis 三剑客 generator配置 、mybatis plugin

热门文章

  1. 洛谷——P2298 Mzc和男家丁的游戏
  2. KS103超声波测距模块
  3. Java服务器获取客户端的ip
  4. Base64的空格 + 问题...
  5. android中MVC,MVP和MVVM三种模式详解析
  6. 创建pycharm项目时项目解释器的选择
  7. chrome插件网站
  8. 笨鸟不乖 是这么设计Android项目架构的
  9. 2016-1-8 windows 7下安装mysql及其配置和运用
  10. TCP连接建立与终止,及状态转换