【题目链接】 http://acm.hdu.edu.cn/showproblem.php?pid=5823

【题目大意】

  定义一张无向图的价值:给每个节点染色使得每条边连接的两个节点颜色不相同的最少颜色数。   

  对于给定的一张由n个点组成的无向图,求该图的2^n-1张非空子图的价值。

【题解】

  设f[i][S]表示i种颜色覆盖S这个集合的方案数,我们只要得到最小的i,f[i][S]大于0,那么i就是S集合的答案。显然有f[i][S]=∑f[1][u]×f[i−1][v](u|v==S),这个怎么求呢= =,承蒙Claris教导,get新技能FWT,处理位运算形式的卷积,所以我们现在只要求n次FWT,就可以得到答案。

【代码】

#include<cstdio>
const int N=18,M=1<<N;
char s[N+2];
int T,n,i,j,g[N],f[N+1][M],h[M];
unsigned int pow[M],ans;
void FWT(int*a,int n){
for(int d=1;d<n;d<<=1)for(int m=d<<1,i=0;i<n;i+=m)for(int j=0;j<d;j++){
a[i+j+d]=a[i+j]+a[i+j+d];
}
}
void UFWT(int*a,int n){
for(int d=1;d<n;d<<=1)for(int m=d<<1,i=0;i<n;i+=m)for(int j=0;j<d;j++){
a[i+j+d]=a[i+j+d]-a[i+j];
}
}
void mul(){
FWT(h,1<<n);
for(i=2;i<=n;i++){
for(j=0;j<1<<n;j++)f[i][j]=f[i-1][j];
FWT(f[i],1<<n);
for(j=0;j<1<<n;j++)f[i][j]*=h[j];
UFWT(f[i],1<<n);
for(j=0;j<1<<n;j++)f[i][j]=!!f[i][j];
}
}
int main(){
scanf("%d",&T);
for(pow[0]=i=1;i<M;i++)pow[i]=pow[i-1]*233;
while(T--){
scanf("%d",&n);
for(i=0;i<n;i++){
scanf("%s",s);g[i]=0;
for(j=0;j<n;j++)if(s[j]=='1')g[i]|=1<<j;
}for(i=0;i<1<<n;i++)f[1][i]=0;
for(i=f[1][0]=1;i<(1<<n);i++){
j=i&-i;
if(!f[1][i-j])continue;
if(g[__builtin_ctz(j)]&i)continue;
f[1][i]=1;
}for(j=0;j<1<<n;j++)h[j]=f[1][j];
mul(); ans=0;
for(i=1;i<1<<n;i++){
for(j=1;!f[j][i];j++);
ans+=j*pow[i];
}printf("%u\n",ans);
}return 0;
}

  

HDU 5823 color II(FWT)的更多相关文章

  1. hdu 5823 color II——子集dp(独立集)

    题目:http://acm.hdu.edu.cn/showproblem.php?pid=5823 独立集染一种颜色.在这个基础上枚举子集来dp. 状压一样地存边真是美妙. 2^32是1ll<& ...

  2. hdu 5823 color II —— 子集DP

    题目:http://acm.hdu.edu.cn/showproblem.php?pid=5823 看博客:http://www.cnblogs.com/SilverNebula/p/5929550. ...

  3. hdu 5823 color II 状压dp

    题目链接 给n个点 n<=18. 然后给出它们两两之间是否有边相连. 问你这个图的所有子集,最少要用多少种颜色来染色, 如果两个点相连, 那么这两个点不能染同样的颜色. 先预处理出所有的点独立集 ...

  4. HDU 5823 color II

    dp[i]表示i子图的最小染色数目. dp[i]=min( dp[i], dp[j]+1 ), j是i的子集,并且j图内的点没有边相连. 高效率枚举i子集的方法:for(int j=i;j;j=(j- ...

  5. HDU 3567 Eight II(八数码 II)

    HDU 3567 Eight II(八数码 II) /65536 K (Java/Others)   Problem Description - 题目描述 Eight-puzzle, which is ...

  6. HDU 5938 Four Operations(四则运算)

    p.MsoNormal { margin: 0pt; margin-bottom: .0001pt; text-align: justify; font-family: Calibri; font-s ...

  7. HDU 5775 Bubble Sort(冒泡排序)

    p.MsoNormal { margin: 0pt; margin-bottom: .0001pt; text-align: justify; font-family: Calibri; font-s ...

  8. HDU 1711 Number Sequence(数列)

    HDU 1711 Number Sequence(数列) Time Limit: 10000/5000 MS (Java/Others) Memory Limit: 32768/32768 K (Ja ...

  9. HDU 1005 Number Sequence(数列)

    HDU 1005 Number Sequence(数列) Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Jav ...

随机推荐

  1. java/php/c#版rsa签名以及验签实现

    本文为转载,请转载请注明地址: 原文地址为        http://xw-z1985.iteye.com/blog/1837376 在开放平台领域,需要给isv提供sdk,签名是Sdk中需要提供的 ...

  2. [转]easyui常用控件及样式收藏

    CSS类定义: div easyui-window                               window窗口样式 属性如下: 1)       modal:是否生成模态窗口.tru ...

  3. 【转】MUD教程--巫师入门教程2

    简单的人物原则上只要有 set_name<名字> . combat_exp <经验>就行了,当然我们总得稍微多添一点了.inherit NPC;void create(){ s ...

  4. NET Core 的 Views

    NET Core 十种方式扩展你的 Views 原文地址:http://asp.net-hacker.rocks/2016/02/18/extending-razor-views.html作者:Jür ...

  5. Linux主要发行版本介绍

    Linux主要发行版本介绍 1.Red Hat Linux Red Hat是一个比较成熟的Linux版本,无论在销售还是装机量上都比较可观.该版本从4.0开始同时支持Intel.Alpha及Sparc ...

  6. 这才是正确删除 office 的方式

    https://support.office.com/zh-cn/article/%E9%80%9A%E8%BF%87%E5%9C%A8%E9%87%8D%E6%96%B0%E5%AE%89%E8%A ...

  7. [原]容器学习(一):动手模拟spring的IoC

    介绍 学习经典框架的实现原理以及设计模式在其实际中的运用,是非常有必要的,可以让我们更好进行面向对象. 本篇文章就来模拟Spring的IOC功能,明白原理后,可以更好的使用它,进而为进行面向对象提供一 ...

  8. 每天学点Linux:七

    Shell编程 shell变量类型: 只有字符串型,变量可以被赋值,被修改,被引用. shell变量命名方法:第一个字符为字母,其余字符可以是字母,数字或下划线. 变量引用:在变量名前加$号,代表变量 ...

  9. JavaEE Tutorials (17) - Java消息服务示例

    17.1JMS示例概述23317.2编写简单的JMS应用233 17.2.1启动JMS提供者234 17.2.2创建JMS受管理对象234 17.2.3构建所有简单示例235 17.2.4发送消息23 ...

  10. 关于重复记录和外部 ID (CRM导入提示已找到重复的查找引用)

    http://docs.huihoo.com/oracle/crm-on-demand/21/local/html/Release21_SimpleChinese/index.htm?toc.htm? ...