要进行两次dp,

第一个,dp[i],1<=i<=(1<<n)

其中用i的二进制形式表示已选择的点。

dp[i] 用来保存i中的点构成一个连通块,边集多少种可能。

转移方程:

        save[] = ;//这里用save[i]表示dp[i]
for(int i=;i<(<<n);i++)
{
int ti = i-lowbit(i); //一定选择最后一个点,使之有序
int j = ti;
long long tmp=;//问题转化为对立问题,记录有多少不连通边集的情况,all[i]表示i中的点,边集的所有可能情况。
for(;j>;j=(j-)&ti)
{
tmp += save[i-j]*all[j];
tmp %= MOD;
}
save[i] = (all[i]-tmp+MOD)%MOD;
}

第二次dp,套路基本相同。

dp[i][j] 表示恰有(i+1)个连通块,且含j中的点的所有可能。

转移方程:

     for(int i=;i<kk;i++)
{
for(int j=;j<(<<n);j++)
{
int tj= j-lowbit(j);
for(int k=tj; k>;k = (k-)&tj )
{
dp[i][j] += dp[i-][k]*save[j-k];
dp[i][j] %= MOD;
}
}
}
//
// main.cpp
// Astar160529
//
// Created by 陈加寿 on 16/5/29.
// Copyright © 2016年 chenhuan001. All rights reserved.
// #include <iostream>
#include <stdio.h>
#include <string.h>
#include <math.h>
#include <algorithm>
using namespace std; #define MOD 1000000009 long long dp[][<<];
int mat[][];
long long save[<<];
long long s2[];
long long all[<<]; int lowbit(int x)
{
return x&(-x);
} void test()
{
int cnt=;
for(int i=;i<(<<);i++)
{
for(int j=i;j>;j=(j-)&i)
{
cnt++;
}
}
cout<<cnt<<endl;
cout<<(<<)<<endl;
} int main() { s2[] = ;
for(int i=;i <= *;i++)
s2[i] = (*s2[i-])%MOD; //test();
int T;
cin>>T; int tt=;
while(T--)
{
int kk,n,m;
scanf("%d%d%d",&n,&m,&kk);
int cnt0=;
memset(mat,,sizeof(mat));
for(int i=;i<m;i++)
{
int a,b;
scanf("%d%d",&a,&b);
a--; b--;
if(a==b) cnt0++;
else
{
mat[a][b] = mat[b][a] = ;
}
} memset(save,,sizeof(save));
memset(all,,sizeof(all));
memset(dp,,sizeof(dp)); for(int i=;i<(<<n);i++)
{
int tcnt=;
for(int j=;j<n;j++)
{
if( ((<<j)&i) !=)
{
for(int k=j+;k<n;k++)
{
if( ((<<k)&i) != )
{
tcnt += mat[j][k];
}
}
}
}
all[i] = s2[tcnt];
} save[] = ;
for(int i=;i<(<<n);i++)
{
int ti = i-lowbit(i);
int j = ti;
long long tmp=;
for(;j>;j=(j-)&ti)
{
tmp += save[i-j]*all[j];
tmp %= MOD;
}
save[i] = (all[i]-tmp+MOD)%MOD;
dp[][i] = save[i];
} for(int i=;i<kk;i++)
{
for(int j=;j<(<<n);j++)
{ int tj= j-lowbit(j);
for(int k=tj; k>;k = (k-)&tj )
{
dp[i][j] += dp[i-][k]*save[j-k];
dp[i][j] %= MOD;
}
}
}
printf("Case #%d:\n",tt++); cout<<dp[kk-][(<<n)-]*s2[cnt0]%MOD<<endl; } return ;
}

CODE

hdu 5713(状态压缩DP)的更多相关文章

  1. HDU 1074 (状态压缩DP)

    题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=1074 题目大意:有N个作业(N<=15),每个作业需耗时,有一个截止期限.超期多少天就要扣多少 ...

  2. HDU 3341 状态压缩DP+AC自动机

    题目大意: 调整基因的顺序,希望使得最后得到的基因包含有最多的匹配串基因,使得所能达到的智商最高 这里很明显要用状态压缩当前AC自动机上点使用了基因的情况所能达到的最优状态 我最开始对于状态的保存是, ...

  3. hdu 4284 状态压缩dp

    题意: 有N 个点的无向图,要去其中 h个地点做事,做事需要先办理护照,之后可以挣一定数量的钱,知道了一开始有的总钱数,和 一些城市之间           道路的花费,问可不可以在 指定的 h 个城 ...

  4. hdu 2167 状态压缩dp

    /* 状态转移方程:dp[i][j]=Max(dp[i][j],dp[i-1][k]+sum[i][j]); */ #include<stdio.h> #include<string ...

  5. HDU 4856 (状态压缩DP+TSP)

    题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=4856 题目大意:有一个迷宫.迷宫里有些隧道,每个隧道有起点和终点,在隧道里不耗时.出隧道就耗时,你的 ...

  6. HDU 4640 状态压缩DP 未写完

    原题链接:http://acm.hdu.edu.cn/showproblem.php?pid=4640 解题思路: 首先用一个简单的2^n*n的dp可以求出一个人访问一个给定状态的最小花费,因为这i个 ...

  7. 2016"百度之星" - 初赛(Astar Round2A)1002 / HDU 5691 状态压缩DP

    Sitting in Line Problem Description   度度熊是他同时代中最伟大的数学家,一切数字都要听命于他.现在,又到了度度熊和他的数字仆人们玩排排坐游戏的时候了.游戏的规则十 ...

  8. HDU 5067 (状态压缩DP+TSP)

    题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=5067 题目大意:蓝翔挖掘机挖石子.把地图上所有石子都运回起点,问最少耗时. 解题思路: 首先得YY出 ...

  9. hdu 4539(状态压缩dp)

    题意:曼哈顿距离是指:|x1-x2|+|y1-y2|,只要知道这个概念题意就懂了. 分析:这道题与前面做的几道题有所不同,因为当前行不仅与前一行有关,而且与前两行有关,所以我们开数组的时候还要记录前两 ...

随机推荐

  1. MVC模式:实现数据库中数据的增删改查功能

    *.数据库连接池c3p0,连接mysql数据库: *.Jquery使用,删除时跳出框,确定是否要删除: *.使用EL和JSTL,简化在jsp页面中插入的java语言 1.连接数据库 (1)导入连接数据 ...

  2. DBUtils开源JDBC类库,对JDBC简单封装(作用是:简化编码工作量,同时不会影响程序的性能)

    DBUtils:提高了程序的性能,编程更加简便 架包 mysql-connector-java-jar commons-dbcp-1.4jar commons-pool-1.5.5jar common ...

  3. CSU 1325: A very hard problem 中南月赛的一道题。

    1325: A very hard problem Time Limit: 3 Sec  Memory Limit: 160 MBSubmit: 203  Solved: 53[Submit][Sta ...

  4. 使用 JavaScript

    我们要用 JavaScript,但是把它写在哪里呢?   这里 ↘   1. HTML 页面中 .   2. 单独的一个文件中,文件后缀名是“.js”.     ——————————————————— ...

  5. 【Nginx】上传文件的大小限制

    今天导入一份Excel文件,浏览器报“413”HTTP异常码. 第一反应检查应用程序所设的文件大小的过滤:第二个检查JS上传的文件大小限制. 后来,转念一想,有可能是Nginx过滤的,马上查看erro ...

  6. 【转载】COM的多线程模型

    原文:COM的多线程模型 COM的多线程模型是COM技术里头最难以理解的部分之一,很多书都有涉及但是都没有很好的讲清楚.很多新人都会在这里觉得很迷惑,google大神能搜到一篇vckbase上的文章, ...

  7. R语言画图基础参数设置

    Graphical Parameters You can customize many features of your graphs (fonts, colors, axes, titles) th ...

  8. c#扩展方法的理解(一:初识)

    扩展方法是静态方法,是类的一部分,但是实际上没有放在类的源代码中. 扩展方法所在的类也必须被声明为static C#只支持扩展方法,不支持扩展属性.扩展事件等. 扩展方法的第一个参数是要扩展的类型,放 ...

  9. PHPwebshell分析

    这几天已知在做webshell的检测,JSP的不说了,特征检测起来很好匹配到,而且全是一家亲,互相模仿的居多. 今天看了一篇文章,看到14年蘑菇的webshell的后门然后很不错. ========= ...

  10. jquery初涉,First Blood

    jquery可以帮助干的事情有: 遍历HTML文档 操作DOM 处理事件 执行动画 开发Ajax操作 优点就不在这儿扯蛋了~ 1.jquery环境配置 jquery不需要安装,只需要将下载的jquer ...