【题目链接】 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. leetcode Trapping Rain Water pthon

    class Solution(object): def trap(self,nums): leftmosthigh = [0 for i in range(len(nums))] leftmax=0 ...

  2. JVM学习之常见溢出类型

    Java堆 所有对象的实例分配都在Java堆上分配内存,堆大小由-Xmx和-Xms来调节,sample如下所示: public class HeapOOM { static class OOMObje ...

  3. Android 数据适配器

    把复杂的数据(数组.链表.数据库.集合等)填充到指定的视图界面上.   arrayAdapter(数组适配器):      用于绑定一些格式单一的数据,数据源:数据或者集合.   private Li ...

  4. 什么是Web前端,Web前端是做什么的?

    什么是Web前端 Web前端,顾名思义是来做Web的前端的.而Web前端开发应该就是来开发基于Web前端的相关应用的或者说是来开发前端的.那么,前端又是什么呢?我们这里所说的前端泛指Web前端,也就是 ...

  5. getElementByID、getElementsByName、getElementsByTagName实例详解

    getElementByID.getElementsByName.getElementsByTagName实例详解 本文通过实例,详细介绍了getElementByID.getElementsByNa ...

  6. linux文件名乱码解决办法

    1.linux解压压缩文件乱码 unzip -O CP936 xxx.zip 2.一般文件用convmv sudo convmv -f gbk -t utf-8 -r --notest /your_d ...

  7. Oracle EBS-SQL (GL-3):从总帐追溯到发票

    SELECT je_header_id, je_line_num, trx_class_name, trx_type_name, trx_number_displayed, trx_date,comm ...

  8. Delphi COM编程技术三类型库(库文件中的工具栏,很全)

    在COM组件的使用和开发过程中经常需要获取有关组件的信息.而COM组件以二进制代码的形式发布,如果不借助特定的工具这些相关信息将难以被获取.通过访问类型库就可以查看COM组件的信息. 一.类型库的基础 ...

  9. #include <string>

    1 append(string T&);字符串拼接 2 c_str string.c_str是Borland封装的String类中的一个函数,它返回当前字符串的首字符地址. 3 empty() ...

  10. kafka学习(二)-zookeeper集群搭建

    zookeeper概念 ZooKeeper是一个分布式的,开放源码的分布式应用程序协调服务,它包含一个简单的原语集,分布式应用程序可以基于它实现同步服务,配置维护和命名 服务等.Zookeeper是h ...