bzoj 4455 [Zjoi2016]小星星 树形dp容斥
4455: [Zjoi2016]小星星
Time Limit: 10 Sec Memory Limit: 512 MB
Submit: 643 Solved: 391
[Submit][Status][Discuss]
Description
Input
Output
Sample Input
1 2
1 3
1 4
4 1
4 2
4 3
Sample Output
HINT
题解:JudgeOnline/upload/201603/4455.txt
Source
这道题目的画风十分新奇,题意我一开始都没怎么看懂,
题意:就是给你n个点的图和一棵树,然后将树重新标号,使得其在图中存在。
20分直接枚举全排列就可以了
40分的话dp+优化,考试的时候可以想想,类似那道暴力状态压缩转移那道题
原来的dp的话 f[i][j][sta]表是i这颗子树,i为j颜色,用sta填充,&&(j-1)那样去做,渐进3^n。
这样复杂度是 3^n*n^2
对于正解,因为n不是特别的大,而且在树上重新编号
就可以容斥,因为如果在树上任意编号的话,就是每次枚举编号集合,
这样的dp就可以转化为f[i][j]表示将i编号为j的方案数,这样的dp过程复杂度是O(n^3)
所以这样总的复杂度是(2^n*n^3)
1 #pragma GCC optimize(2) 2 #pragma G++ optimize(2) 3 #include<iostream> 4 #include<algorithm> 5 #include<cmath> 6 #include<cstdio> 7 #include<cstring> 8 9 #define ll long long 10 #define N 22 11 using namespace std; 12 inline int read() 13 { 14 int x=0,f=1;char ch=getchar(); 15 while(!isdigit(ch)){if(ch=='-')f=-1;ch=getchar();} 16 while(isdigit(ch)){x=(x<<1)+(x<<3)+ch-'0';ch=getchar();} 17 return x*f; 18 } 19 20 ll ans; 21 int n,m,num; 22 int a[N],p[N][N]; 23 ll f[N][N]; 24 int cnt,hed[N],nxt[N*2],rea[N*2]; 25 26 void add(int u,int v) 27 { 28 nxt[++cnt]=hed[u]; 29 hed[u]=cnt; 30 rea[cnt]=v; 31 } 32 void cal(int u,int fa) 33 { 34 for (int i=hed[u];i!=-1;i=nxt[i]) 35 { 36 int v=rea[i]; 37 if(v==fa)continue; 38 cal(v,u); 39 } 40 for (int i=1;i<=num;i++) 41 { 42 f[u][i]=1; 43 for (int j=hed[u];j!=-1;j=nxt[j]) 44 { 45 int v=rea[j];ll w=0; 46 if(v==fa)continue; 47 for (int k=1;k<=num;k++) 48 if(p[a[i]][a[k]])w+=f[v][k]; 49 f[u][i]*=w; 50 } 51 } 52 } 53 void dfs(int x,int y,int sta) 54 { 55 if(x>n) 56 { 57 num=0; 58 for (int i=1;i<=n;i++)if(!((1<<(i-1))&sta))a[++num]=i; 59 cal(1,0); 60 ll res=0; 61 for (int i=1;i<=num;i++) 62 res+=f[1][i]; 63 ans+=y*res; 64 return; 65 } 66 dfs(x+1,y,sta); 67 dfs(x+1,-y,sta+(1<<(x-1))); 68 } 69 int main() 70 { 71 memset(hed,-1,sizeof(hed)); 72 n=read(),m=read(); 73 for (int i=1;i<=m;i++) 74 { 75 int x=read(),y=read(); 76 p[x][y]=1,p[y][x]=1; 77 } 78 for (int i=1;i<n;i++) 79 { 80 int x=read(),y=read(); 81 add(x,y),add(y,x); 82 } 83 dfs(1,1,0); 84 printf("%lld\n",ans); 85 }
转载于:https://www.cnblogs.com/fengzhiyuan/p/8487198.html
bzoj 4455 [Zjoi2016]小星星 树形dp容斥相关推荐
- bzoj 4455: [Zjoi2016]小星星 树形dp+容斥原理
题意 给出一棵树和一个图,问有多少种方法把树的节点标号使得其在改图中至少有一棵生成树与原来的树是重构的. n<=17 分析 想到了容斥,但是没想到从哪里容斥... 显然题目给了两个限制,一个是原 ...
- BZOJ4455 / UOJ185 小星星 —— 树形dp + 容斥
题目链接:点我啊╭(╯^╰)╮ 题目大意: nnn 个点 mmm 条边的图 破坏后现在变成 nnn 个点的树 问这颗树每个点映射回原来的图的总方案数 映射即现在的两点存在边,原 ...
- bzoj 4455: [Zjoi2016]小星星
链接 http://www.lydsy.com/JudgeOnline/problem.php?id=4455 dp+容斥题意大约是树上的点满足与图上的点一一对应并且图中两两有边,树中也两两有边,求满 ...
- [BZOJ4455][UOJ185][Zjoi2016]小星星(树形DP+容斥)
将问题抽象化: 一个nnn个节点的树,和一个n" role="presentation" style="position: relative;"> ...
- P3349-[ZJOI2016]小星星【树形dp,容斥】
正题 题目链接:https://www.luogu.com.cn/problem/P3349 题目大意 nnn个点的一棵树,再给出一张图,树上每个点对应图上每个点后要求树上的边图上都有,求有多少种对应 ...
- P5405-[CTS2019]氪金手游【树形dp,容斥,数学期望】
前言 话说在LojLojLoj下了个数据发现这题的名字叫fgofgofgo 正题 题目链接:https://www.luogu.com.cn/problem/P5405 题目大意 nnn张卡的权值为1 ...
- [LOJ#3124][CTS2019]氪金手游(概率 + 树形 DP + 容斥)
Address 洛谷 P5405 LOJ #3124 Solution 先考虑如果以某个点(下面定为 111 )为根时,如果所有的限制二元组 (u,v)(u,v)(u,v) 都满足 uuu 是 vvv ...
- ARC101E Ribbons on Tree 树形dp 容斥
题目链接 题意: 给你一棵nnn个点的树,nnn是偶数,把这些点分成n2\frac{n}{2}2n个点对,每个点对会把路径上的所有边覆盖,问你每条边至少覆盖一次有多少种配对方式.n<=5000 ...
- [容斥 状压DP 树形DP] BZOJ 4455 [Zjoi2016]小星星 UOJ #185 【ZJOI2016】小星星
杜老师说的哦 据说有人n*3^n卡过去 ? UOJ上需要卡常哦 #include<cstdio> #include<cstdlib> #include<algorithm ...
最新文章
- Win10~KinectV1开发
- python网络开发框架_greenev首页、文档和下载 - Python网络服务框架 - OSCHINA - 中文开源技术交流社区...
- nginx源码分析之模块初始化
- 前端学习(2309):react之同级传值
- typora用Pandoc导出html,Typora安装 Pandoc实现导出功能
- netty中的引导Bootstrap服务端
- color 的一些处理
- hadoop 分布式切换为伪分布式(单机)
- 公布中秋福利中奖名单
- 从优秀到卓越 pdf_演讲口才培训:演讲能力是卓越领导者需要具备的能力
- ubuntu结束进程快捷键_ubuntu快捷键详细版
- 程序员应该有的一些好习惯!
- linux蓝屏漏洞,WIN 10漏洞:访问特定本地设备导致系统崩溃
- 直播入口地址的数据库修改
- 基于javaweb的宠物医院预约管理系统设计和实现(java+springboot+mysql+ssm)
- 4.15 使用渐变映射命令制作艺术效果 [原创Ps教程]
- 基于物化视图创建分区(分区的物化视图)
- 作业盒子生端AndrOid,作业盒子小学下载安装学生版
- 基于Qt的ARM-Linux系统测试工具
- 回填用土好还是砂石料好_砂石土的一般配比