CodeForces 762F. Tree nesting
来源:互联网 发布:网络电视32寸多少钱 编辑:程序博客网 时间:2024/06/06 02:43
You are given two trees (connected undirected acyclic graphs) S and T.
Count the number of subtrees (connected subgraphs) of S that are isomorphic to tree T. Since this number can get quite large, output it modulo 109 + 7.
Two subtrees of tree S are considered different, if there exists a vertex in S that belongs to exactly one of them.
Tree G is called isomorphic to tree H if there exists a bijection f from the set of vertices of G to the set of vertices of H that has the following property: if there is an edge between vertices A and B in tree G, then there must be an edge between vertices f(A) and f(B) in tree H. And vice versa — if there is an edge between vertices A and B in tree H, there must be an edge between f - 1(A) and f - 1(B) in tree G.
The first line contains a single integer |S| (1 ≤ |S| ≤ 1000) — the number of vertices of tree S.
Next |S| - 1 lines contain two integers ui and vi (1 ≤ ui, vi ≤ |S|) and describe edges of tree S.
The next line contains a single integer |T| (1 ≤ |T| ≤ 12) — the number of vertices of tree T.
Next |T| - 1 lines contain two integers xi and yi (1 ≤ xi, yi ≤ |T|) and describe edges of tree T.
On the first line output a single integer — the answer to the given task modulo 109 + 7.
51 22 33 44 531 22 3
3
32 33 131 21 3
1
71 21 31 41 51 61 744 14 24 3
20
51 22 33 44 544 14 24 3
0
吐槽:必须吐槽,这里的subtree不是指子树,而是指连通子图......
题解:状压DP
dp[i][j]表示S中i的子树和右兄弟(不包括i)完成T的状态为j的方案数
对于T预处理bit数组,表示它的儿子状压后的表示
然后S可以直接以1为根,枚举T的根即可
dfs(f,y,V)表示f的第y个儿子,状态为V方便转移
记忆化搜索即可
答案就是S与T同构/T自同构
复杂度O( ( |T| ^ 2 ) * ( 2^ |T| ) * |S| )
#include <bits/stdc++.h>using namespace std;const int MAXN = 1001;const int MAXV = 1 << 12;const int mod = 1e9 + 7;inline int Pow(int x, int y){int s = 1;for( ; y ; y >>= 1, x = 1ll * x * x % mod ) if( y & 1 ) s = 1ll * s * x % mod;return s;}inline int inv(int x) { return Pow( x, mod - 2 ); }struct edge { int to, nxt; };struct tree{edge e[MAXN << 1];int n, cnt;int head[MAXN], son[MAXN][MAXN], size[MAXN], bit[MAXN];inline void addedge(int x, int y) { e[ ++cnt ].to = y; e[ cnt ].nxt = head[ x ]; head[ x ] = cnt; }inline void read(){scanf( "%d", &n );for( int i = 1 ; i < n ; i++ ) { int x, y; scanf( "%d%d", &x, &y ); addedge( x, y ); addedge( y, x ); }}inline void dfs(int x, int fa){size[ x ] = bit[ x ] = 0;for( int i = head[ x ] ; i ; i = e[ i ].nxt ) if( e[ i ].to ^ fa )dfs( son[ x ][ ++size[ x ] ] = e[ i ].to, x ), bit[ x ] |= 1 << e[ i ].to - 1; }}S, T;int dp[MAXN][MAXV], ans, ans2;bool vis[MAXN][MAXV];inline int dfs(int f, int y, int V){if( !y ) return !V;int x = S.son[ f ][ y ];if( vis[ x ][ V ] ) return dp[ x ][ V ];vis[ x ][ V ] = 1;int &ret = dp[ x ][ V ];ret = dfs( f, y - 1, V );for(int i = 0 ; i < T.n ; i++ ) if( V >> i & 1 )ret = ( 1ll * dfs( f, y - 1, V ^ ( 1 << i ) ) * dfs( x, S.size[ x ], T.bit[ i + 1 ] ) + ret ) % mod;return ret; }int main(){S.read();T.read();S.dfs( 1, 0 );for( int i = 1 ; i <= T.n ; i++ ){memset( dp, 0, sizeof dp );memset( vis, 0, sizeof vis );T.dfs( i, 0 );for( int j = 1 ; j <= S.n ; j++ ) ( ans += dfs( j, S.size[ j ], T.bit[ i ] ) ) %= mod;}S = T;S.dfs( 1, 0 );for( int i = 1 ; i <= T.n ; i++ ){memset( dp, 0, sizeof dp );memset( vis, 0, sizeof vis );T.dfs( i, 0 );( ans2 += dfs( 1, S.size[ 1 ], T.bit[ i ] ) ) %= mod;}ans = 1ll * ans * inv( ans2 ) % mod;return printf( "%d\n", ans ), 0;}
- CodeForces 762F. Tree nesting
- CodeForces 762F. Tree nesting
- [Educational Codeforces Round 17 F (762F)] Tree nesting
- CodeForces#375 - F-st-Spanning Tree 构造
- Codeforces Gym 100623F Problem F. Fenwick Tree
- codeforces 379F New Year Tree 在线LCA
- Codeforces Round #375 (Div. 2) F. st-Spanning Tree
- Codeforces 723F st-Spanning Tree(连通性乱搞)
- Codeforces Round #375 (Div. 2) F. st-Spanning Tree
- Codeforces 723F st-Spanning Tree【贪心Kruskal】
- [Segment tree Beats! || 分块] Codeforces 793F Tinkoff Challenge
- f:Tree
- Codeforces 659F F
- [并查集 构造] Codeforces 723F#375 (Div. 2) F. st-Spanning Tree
- ACM ICPC 2008–2009, NEERC, Problem F Fenwick Tree(找规律,打表) Codeforces Gym 100623F
- Codeforces Round #375 (Div. 2) -- F. st-Spanning Tree(并查集 构造生成树)
- Codeforces 234 F. Fence
- 【Codeforces 500F】Dp
- 算法训练 5-1最小公倍数
- win10,ubuntu双系统和win10,红帽双系统的安装的异同
- OI心得::学会经常使用类,重载运算符和库。
- nginx配置虚拟主机
- Matlab编程与数据类型 -- 开关语句switch/end
- CodeForces 762F. Tree nesting
- 【Android】Android中的RecyclerView的基本使用
- MaterialDesign主题出现闪退现象
- 【Untiy&射线】射线基础
- 我眼中的AJAX
- go语言快速入门:简介(1)
- 【Python】webshell扫描初始版本+源码分析
- 安卓项目报错-Unable to resolve target 'android-“”'
- [BZOJ1283]序列(费用流)