UOJ #185【ZJOI2016】 小星星
题目链接:小星星
首先有个暴力很好想。令\(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】 小星星的更多相关文章
- ZJOI2016 小星星 题解
我一生之敌是状压 本文发表于 洛谷博客:https://www.luogu.com.cn/blog/LoveMC/solution-p3349 Cnblogs:https://www.cnblogs. ...
- BZOJ 4455: [Zjoi2016]小星星 [容斥原理 树形DP]
4455: [Zjoi2016]小星星 题意:一个图删掉一些边形成一棵树,告诉你图和树的样子,求让图上的点和树上的点对应起来有多少方案 看了很多题解又想了一段时间,感觉题解都没有很深入,现在大致有了自 ...
- 4455[Zjoi2016]小星星 容斥+dp
4455: [Zjoi2016]小星星 Time Limit: 10 Sec Memory Limit: 512 MBSubmit: 527 Solved: 317[Submit][Status] ...
- [ZJOI2016]小星星&[SHOI2016]黑暗前的幻想乡(容斥)
这两道题思路比较像,所以把他们放到一块. [ZJOI2016]小星星 题目描述 小Y是一个心灵手巧的女孩子,她喜欢手工制作一些小饰品.她有n颗小星星,用m条彩色的细线串了起来,每条细线连着两颗小星星. ...
- 【BZOJ 4455】 4455: [Zjoi2016]小星星 (容斥原理+树形DP)
4455: [Zjoi2016]小星星 Time Limit: 10 Sec Memory Limit: 512 MBSubmit: 426 Solved: 255 Description 小Y是 ...
- 洛谷 P3349 [ZJOI2016]小星星 解题报告
P3349 [ZJOI2016]小星星 题目描述 小\(Y\)是一个心灵手巧的女孩子,她喜欢手工制作一些小饰品.她有\(n\)颗小星星,用\(m\)条彩色的细线串了起来,每条细线连着两颗小星星. 有一 ...
- bzoj 4455 [Zjoi2016]小星星 树形dp&容斥
4455: [Zjoi2016]小星星 Time Limit: 10 Sec Memory Limit: 512 MBSubmit: 643 Solved: 391[Submit][Status] ...
- 【题解】P3349 [ZJOI2016]小星星 - 子集dp - 容斥
P3349 [ZJOI2016]小星星 声明:本博客所有题解都参照了网络资料或其他博客,仅为博主想加深理解而写,如有疑问欢迎与博主讨论✧。٩(ˊᗜˋ)و✧*。 题目描述 小 \(Y\) 是一个心灵手巧 ...
- uoj #185. 【ZJOI2016】小星星
#185. [ZJOI2016]小星星 小Y是一个心灵手巧的女孩子,她喜欢手工制作一些小饰品.她有 nn 颗小星星,用 mm 条彩色的细线串了起来,每条细线连着两颗小星星.有一天她发现,她的饰品被破坏 ...
随机推荐
- python之xlwt模块列宽width、行高Heights详解
今天用python操作excel时,发现xlwt的API中没有对width.height有更多介绍,且使用时也不知道width取多少合适.现在这做个详细介绍 使用版本: python:2.7.5 xl ...
- java启动3个线程轮流打印数字
转自:http://blog.csdn.net/u014011112/article/details/50988769 http://blog.csdn.net/perrywork/article/d ...
- Mysql limit offset用法举例
转自:http://blog.csdn.net/iastro/article/details/53037600 Mysql limit offset示例 例1,假设数据库表student存在13条数据 ...
- angular -- 无刷新做分页
无刷新做分页参考地址: http://www.jq22.com/demo/angular201707111100/ 示例代码: <!DOCTYPE html> <html lang= ...
- postgresql架构基础(转)-(1)
PostgreSQL使用一种客户端/服务器的模型.一次PostgreSQL会话由下列相关的进程(程序)组成: 一个服务器进程,它管理数据库文件.接受来自客户端应用与数据库的联接并且代表客户端在数据库上 ...
- 170717、springboot编程之mybatis数据库开发和aop拦截
一.springboot整合mybaits (1)新建maven project; 新建一个maven project,取名为:spring-boot-mybatis (2)在pom.xml文件中引入 ...
- sql 将一张表中的数据插入到另一张表
将表T_wz_wz中的部分数据插入到表t_wz_kc: insert into t_wz_kc(wzid,jldwid,kcsl,yfpkcsl,cshwcbz) select wzid,jldwid ...
- JS/Java/Python格式化金额
//java代码 public static void main(String[] args) { DecimalFormat myformat = new DecimalFormat(); ...
- HI3518E用J-link烧写裸板fastboot u-boot流程
Hi3518E的裸板烧写fastboot是不能像HI3531那样,可以通过FB直接烧写.遵循ARM9的烧写流程.其中一般u-boot的烧写流程可分为几类:第一:通过编程器芯片直接烧写:第二通过RVDS ...
- 内核通信之Netlink源码分析-用户内核通信原理3
2017-07-06 上节主讲了用户层通过netlink和内核交互的详细过程,本节分析下用户层接收数据的过程…… 有了之前基础知识的介绍,用户层接收数据只涉及到一个核心调用readmsg(), 其他的 ...