题目链接:小星星

  首先有个暴力很好想。令\(f_{i,j,S}\)表示把\(i\)这棵子树对应到原图中的\(S\)集合,\(i\)号点对应到了\(j\)号点的方案数。这玩意儿复杂度是\(O(3^nn^3)\)的,但是稍微加点优化就能有\(40\)分。

  然后看看这个转移的方程,实际上就是集合或卷积。于是我们就可以优化转移了,总复杂度就变成了\(O(2^nn^4)\)。

  然后我们发现,我们完全可以\(dp\)的整个过程都在\(n\)维前缀和类似物下进行,最后再用差分类似物弄回来就可以了。于是复杂度成功降为\(O(2^nn^3)\)。

  这个复杂度算出来好像是会\(TLE\)的样子……但是复杂度是不满的,所以我们卡一卡常数就能\(AC\)了。

  我写的东西比较丑陋,只能卡着时间过去……然后去膜了一发王队的代码,发现空间复杂度都可以只需\(O(2^n)\)……只要每次先枚举状态\(S\),再对整棵树进行\(dp\)就可以了。而且这样做常数也非常之小。

  至于正解的容斥,就先坑在这里吧。

  下面贴代码:

#include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
#include<cmath>
#define File(s) freopen(s".in","r",stdin),freopen(s".out","w",stdout)
#define N 17 using namespace std;
typedef long long llg; int n,m,lim,mp[1<<N],G[N];
llg f[N][N],res,g[1<<N];
int h[N][N],lh[N]; void dfs(int u,int fa,int S){
for(int i=S;i;i-=i&(-i)) f[u][mp[i&(-i)]]=1;
for(int l=0;l<lh[u];l++){
if(h[u][l]==fa) continue;
dfs(h[u][l],u,S);
for(int i=S,x;i;i-=i&(-i)){
res=0; x=mp[i&(-i)];
for(int j=G[x]&S;j;j-=j&(-j))
res+=f[h[u][l]][mp[j&(-j)]];
f[u][x]*=res;
}
}
} int main(){
File("a");
scanf("%d %d",&n,&m); lim=1<<n;
for(int i=1,u,v;i<=m;i++){
scanf("%d %d",&u,&v); u--,v--;
G[u]|=1<<v; G[v]|=1<<u;
}
for(int i=2,u,v;i<=n;i++){
scanf("%d %d",&u,&v); u--,v--;
h[u][lh[u]++]=v,h[v][lh[v]++]=u;
}
for(int i=0;i<n;i++) mp[1<<i]=i;
for(int i=1;i<lim;i++){
dfs(0,-1,i);
for(int j=0;j<n;j++)
if((i>>j)&1) g[i]+=f[0][j];
}
for(int i=0;i<n;i++)
for(int j=0;j<lim;j++)
if((j>>i)&1) g[j]-=g[j^(1<<i)];
printf("%lld",g[lim-1]);
return 0;
}

  BZOJ提交网址:BZOJ 4455 小星星

UOJ #185【ZJOI2016】 小星星的更多相关文章

  1. ZJOI2016 小星星 题解

    我一生之敌是状压 本文发表于 洛谷博客:https://www.luogu.com.cn/blog/LoveMC/solution-p3349 Cnblogs:https://www.cnblogs. ...

  2. BZOJ 4455: [Zjoi2016]小星星 [容斥原理 树形DP]

    4455: [Zjoi2016]小星星 题意:一个图删掉一些边形成一棵树,告诉你图和树的样子,求让图上的点和树上的点对应起来有多少方案 看了很多题解又想了一段时间,感觉题解都没有很深入,现在大致有了自 ...

  3. 4455[Zjoi2016]小星星 容斥+dp

    4455: [Zjoi2016]小星星 Time Limit: 10 Sec  Memory Limit: 512 MBSubmit: 527  Solved: 317[Submit][Status] ...

  4. [ZJOI2016]小星星&[SHOI2016]黑暗前的幻想乡(容斥)

    这两道题思路比较像,所以把他们放到一块. [ZJOI2016]小星星 题目描述 小Y是一个心灵手巧的女孩子,她喜欢手工制作一些小饰品.她有n颗小星星,用m条彩色的细线串了起来,每条细线连着两颗小星星. ...

  5. 【BZOJ 4455】 4455: [Zjoi2016]小星星 (容斥原理+树形DP)

    4455: [Zjoi2016]小星星 Time Limit: 10 Sec  Memory Limit: 512 MBSubmit: 426  Solved: 255 Description 小Y是 ...

  6. 洛谷 P3349 [ZJOI2016]小星星 解题报告

    P3349 [ZJOI2016]小星星 题目描述 小\(Y\)是一个心灵手巧的女孩子,她喜欢手工制作一些小饰品.她有\(n\)颗小星星,用\(m\)条彩色的细线串了起来,每条细线连着两颗小星星. 有一 ...

  7. bzoj 4455 [Zjoi2016]小星星 树形dp&容斥

    4455: [Zjoi2016]小星星 Time Limit: 10 Sec  Memory Limit: 512 MBSubmit: 643  Solved: 391[Submit][Status] ...

  8. 【题解】P3349 [ZJOI2016]小星星 - 子集dp - 容斥

    P3349 [ZJOI2016]小星星 声明:本博客所有题解都参照了网络资料或其他博客,仅为博主想加深理解而写,如有疑问欢迎与博主讨论✧。٩(ˊᗜˋ)و✧*。 题目描述 小 \(Y\) 是一个心灵手巧 ...

  9. uoj #185. 【ZJOI2016】小星星

    #185. [ZJOI2016]小星星 小Y是一个心灵手巧的女孩子,她喜欢手工制作一些小饰品.她有 nn 颗小星星,用 mm 条彩色的细线串了起来,每条细线连着两颗小星星.有一天她发现,她的饰品被破坏 ...

随机推荐

  1. 【BZOJ4099】Trapped in the Haybales Gold STL

    [BZOJ4099]Trapped in the Haybales Gold Description Farmer John has received a shipment of N large ha ...

  2. 【BZOJ1915】[Usaco2010 Open]奶牛的跳格子游戏 DP+单调队列

    [BZOJ1915][Usaco2010 Open]奶牛的跳格子游戏 Description 奶牛们正在回味童年,玩一个类似跳格子的游戏,在这个游戏里,奶牛们在草地上画了一行N个格子,(3 <= ...

  3. 微信小程序 --- app.js文件

    app.js文件是项目的入口文件: //app.js App({ onLaunch: function () { // 展示本地存储能力 var logs = wx.getStorageSync('l ...

  4. Spring中常用的注解(@Entity,@Table,@Column,@Repository,@Service)

    当项目变得比较大的时候,如何还使用hbm.xml文件来配置Hibernate实体就会变得比较复杂.这里Hibernate提供了Annotation注解方式,使得Hibernate的映射文件变得很方便管 ...

  5. postgresql----根据现有表创建新表

    除普通的建表语句"create table table_name(columns);"之外,还可以根据现有表快速的创建新表: 一.使用create table ... (like ...

  6. asp.net SessionState模式的配置及使用

    由于项目dll文件变动比较频繁,而保存登陆的状态又保存在Session中,所以导致用户经常无故掉线(PS:dll变动的时候导致Session).有一种方法可以长期保存session,那就是sessio ...

  7. Page Control

  8. freemarker 判断写法

    1.if条件写法:如果data非空则输出:test<#if data?? >test</#if> 2.为空则输出 <#if !(data??) > test < ...

  9. 阿里云centos7.2 安装mysql 6.5

    [root@111 ~]# uname -aLinux bxhs 3.10.0-327.22.2.el7.x86_64 #1 SMP Thu Jun 23 17:05:11 UTC 2016 x86_ ...

  10. 离线状态 Postman不能开启Postman Interceptor解决

    目前的postman插件如果想正常使用,必须安装Postman Interceptor插件,这样才能直接使用chrome浏览器的cookie等信息,否则postman是无法完成老版本的功能的. 直接使 ...