【Codeforces 949D】Shake It! 【动态规划】
参考: http://blog.csdn.net/gjghfd/article/details/77824901

所求的是满足条件的图中“不同构”的数量,意味着操作的顺序是可以忽略的。考虑若干次操作后得到的一个“World” G,其中某次操作(s(G), t(G))生成的节点为w,则由s(G)到w和由w到t(G)的所有路径及途径点生成的两个子图分别符合“World”的定义。
这意味着我们可以将一个“World”分割成若干个子问题来求解。
不妨令F(N, M)表示经N次操作后得到的s(G)与t(G)之间最小割为M的所有不同构的G的数量。考虑N次操作中所有基于u=s(G), v=t(G)的操作生成的子“world”,如图所示:

则有$$N = \sum_i (a_i + c_i + 1) \\ M = \sum_i \min\{b, d\} $$
这样我们就可以类比背包问题的求解过程,从小到大依次求出g(i, j),并用g(i, j)更新F的答案。
考虑当前要将t组在g(i, j)中的“子世界对”放入背包,而F(x,y)是尚未考虑将g(i, j)作为子世界的情况的世界数量,那么状态转移的过程就相当于在g(i,j)中可重复地选取t个子世界对,使得总操作数变为x+t*i,总割集变为y+t*j。由于“同构”的定义不考虑操作的顺序,上述转移的方案数应为$\binom{g(i, j) + t - 1}{t} $
即状态转移为$$F(x, y) \cdot \binom{g(i, j) + t - 1}{t} \Longrightarrow F(x+t*i, y+t*j)$$
By Asm.Def, contest: Codeforces Round # (Div. ), problem: (D) Shake It!, Accepted, # #include <bits/stdc++.h>
using namespace std;
const int maxn = , mod = ;
typedef long long LL;
int N, M, F[maxn][maxn], G[maxn][maxn], inv[maxn]; void init()
{
scanf("%d%d", &N, &M);
inv[] = ;
for(int i = ;i < maxn;++i)
inv[i] = LL(mod-mod/i) * inv[mod%i] % mod;
}
void work()
{
F[][] = ;
for(int i = ;i <= N;++i) for(int j = ;j < maxn;++j)
{
for(int a = ;a < i;++a)
{
G[i][j] = (G[i][j] + (LL) F[a][j] * F[i--a][j]) % mod;
for(int b = j+;b <= i+ && b < maxn;++b)
{
G[i][j] = (G[i][j] + (LL) F[a][b] * F[i--a][j]) % mod;
G[i][j] = (G[i][j] + (LL) F[a][j] * F[i--a][b]) % mod;
}
}
//get G[i][j]
for(int x = N-;x >= ;--x) for(int y = ;y < maxn;++y) if(F[x][y])
{
int C = ;
for(int t = ;x+t*i <= N && y+t*j < maxn;++t)
{
C = (LL) C * (G[i][j]-+t) % mod * inv[t] % mod;
F[x+t*i][y+t*j] = (F[x+t*i][y+t*j] + (LL) F[x][y] * C) % mod;
}
}
}
printf("%d\n", F[N][M]);
}
int main()
{
init();
work();
return ;
}
动态规划
【Codeforces 949D】Shake It! 【动态规划】的更多相关文章
- Codeforces 839C Journey - 树形动态规划 - 数学期望
There are n cities and n - 1 roads in the Seven Kingdoms, each road connects two cities and we can r ...
- Codeforces 834D The Bakery - 动态规划 - 线段树
Some time ago Slastyona the Sweetmaid decided to open her own bakery! She bought required ingredient ...
- Codeforces 837D Round Subset - 动态规划 - 数论
Let's call the roundness of the number the number of zeros to which it ends. You have an array of n ...
- CodeForces 623E Transforming Sequence 动态规划 倍增 多项式 FFT 组合数学
原文链接http://www.cnblogs.com/zhouzhendong/p/8848990.html 题目传送门 - CodeForces 623E 题意 给定$n,k$. 让你构造序列$a( ...
- Codeforces 101623E English Restaurant - 动态规划
题目传送门 传送门 题目大意 餐厅有$n$张桌子,第$i$张桌子可以容纳$c_i$个人,有$t$组客人,每组客人的人数等概率是$[1, g]$中的整数. 每来一组人数为$x$客人,餐厅如果能找到最小的 ...
- Codeforces 264C Choosing Balls 动态规划
原文链接https://www.cnblogs.com/zhouzhendong/p/CF264C.html 题目传送门 - CF264C 题意 给定一个有 $n$ 个元素的序列,序列的每一个元素是个 ...
- Codeforces 1000G Two-Paths 树形动态规划 LCA
原文链接https://www.cnblogs.com/zhouzhendong/p/9246484.html 题目传送门 - Codeforces 1000G Two-Paths 题意 给定一棵有 ...
- codeforces 17C Balance(动态规划)
codeforces 17C Balance 题意 给定一个串,字符集{'a', 'b', 'c'},操作是:选定相邻的两个字符,把其中一个变成另一个.可以做0次或者多次,问最后可以生成多少种,使得任 ...
- Codeforces 762D Maximum path 动态规划
Codeforces 762D 题目大意: 给定一个\(3*n(n \leq 10^5)\)的矩形,从左上角出发到右下角,规定每个格子只能经过一遍.经过一个格子会获得格子中的权值.每个格子的权值\(a ...
随机推荐
- imperva 默认策略添加例外
创建违规访问 检查违规的告警类型 假如客户的这个目录下真的有这个文件,而且客户非常明确这是一个正常且安全的东西怎么办?我该如何的将它添加到例外? 添加例外的步骤: 再次构造违规的请求: 默认策略添加例 ...
- javascript多投事件的处理 (转)
出处 http://blog.csdn.net/dead_of_winter/article/details/1646367 尽管ecma标准指定了addEventListener这样的方法来实现事件 ...
- 001_Mac键盘图标与对应快捷按键标志汇总
Mac键盘图标与对应快捷按键 ⌘——Command () win键 ⌃ ——Control ctrl键 ⌥——Option (alt) ⇧——Shift ⇪——Caps Lock fn——功能键就是 ...
- No.2 selenium学习之路之八种基本定位
selenium的八种定位方式 1.通过id定位 find_element_by_id() send_keys() 输入框输入字符串 click() 鼠标点击事件 注:send_keys输入 ...
- 洛谷P2279消防局的设立
传送门啦 一个很摸不清头脑的树形dp 状态: $ dp[i][0] $ :选自己 $ dp[i][1] $ :选了至少一个儿子 $ dp[i][2] $ :选了至少一个孙子 ------------- ...
- yum安装Mysql-5.6
MySQL yum库提供了一个简单的和方便的方法来安装和更新MySQL相关的软件包到最新版本. MySQL yum库文档说明:http://dev.mysql.com/doc/mysql-yum-re ...
- sql server 2000系统表sysproperties在SQL 2008中无效的问题
Sqlserver有一个扩展属性系统表sysproperties,因为只接触过MSSQL2005及以后的版本,在生产库2008版本及联机文档上搜了下都找不到这个系统表,后来发现这个系统表在2005版本 ...
- Kubernetes 概述和搭建(多节点)
一.Kubernetes整体概述和架构 Kubernetes是什么 Kubernetes是一个轻便的和可扩展的开源平台,用于管理容器化应用和服务.通过Kubernetes能够进行应用的自动化部署和扩缩 ...
- .gitignore文件如何编写?
.gitignore文件即 项目中不需要被追踪(track)且上传到git系统的文件 <1>忽略文件的原则 a.忽略操作系统自动生成的文件,比如缩略图等 b.忽略编译生成的中间文件.可执行 ...
- 1926: [Sdoi2010]粟粟的书架
大概就是分情况乱搞.. 经典维护二维前缀和暴力+莫队算法 垫底QAQ #include <bits/stdc++.h> using namespace std; namespace my_ ...