题目链接:

http://codeforces.com/problemset/problem/140/E

题意:

圣诞树上挂彩球,要求从上到下挂\(n\)层彩球。已知有\(m\)种颜色的球,球的数量不限。

要求结果对\(p\)取模。然后给你\(n\)个数,表示第 \(i\) 根绳长 \(l_i\),也就是要挂 \(l_i\) 个球。

\(1.\)要求每根绳上相邻彩球颜色不同。

\(2.\)相邻的绳子上挂的彩球种类不能相同。

题解:

我们先解决子问题,先考虑第 \(i\) 层上能放多少个球,\(a[i][j]\)表示长为\(i\)的绳子上放\(j\)种球的方案数,考虑的其实就是\(j\)种小球往\(i\)个无编号的盒子里放,每个盒子放一个,相邻盒子小球不一样,

\(a[i−1][j−1]\)表示\(i−1\)个盒子放\(j−1\)种小球,变成 \(i\) 盒子 \(j\)小球,就是新添加一个小球放进一个新的盒子里。

\(a[i−1][j]\)表示\(i−1\)个盒子\(j\)种小球,新添加一个盒子时可以放除了相邻盒子中的小球外任意小球,即 \((j−1)\) 个。

所以,\(a[i][j]=a[i−1][j−1]+a[i−1][j]∗(j−1)\)。显然这就是第二类斯特林数。

我们再考虑 \(dp[i][j]\)表示在第\(1\)到\(i−1\)根绳子排列合法的情况下,第\(i\)根绳子用 \(j\) 种小球的合法方案数。

那么,\(dp[i][j] = \sum\limits_{i = 1}^{m}\sum\limits_{j = 1 }^{l[i]} [dp[i-1][j]*(绳子i上放j 种小球的合法方案数)-(绳子i与绳子i-1用同样小球的方案数)(i > 1)(j <= l[i-1])]\)。

所以,

绳子\(i\)上放\(j\)种小球的合法情况有: \(a[i][j]*A_k^j\) (其中\(k\) 为可以选择的颜色数量)。

绳子\(i\)与绳子\(i-1\)用同样小球的方案数就是:\(dp[i-1][j]*a[i][j]*A_j^j\)。

最后把该预处理的都预处理一下就可以了。

\(dp\) 那个数组好难开。。。最后\(resize\)一下过了....没有\(c++11\)我可能啥都写不出来....

代码:

#include<bits/stdc++.h>

using namespace std;
const double pi = acos(-1.0);
const double eps = 1e-9;
const int maxn = 1001000; int l[maxn],a[5201][5201],fac[5201],rfac[5201];
//int dp[5201][5201];
std::vector<int> dp[maxn]; int main(int argc, char const *argv[]) {
int n,m,p;
std::cin >> n >> m >> p;
int sz = 0 ;
for(int i=1;i<=n;i++) {
std::cin >> l[i];
//sz = max(l[i],sz);
dp[i].resize(l[i]+1);
}
// vector<vector<int>> dp(sz + 1, vector<int>(sz + 1, 0));
fac[0] = 1;
rfac[0] = 1;
for(int i=1;i<=5010;i++) {
fac[i] = 1LL * fac[i-1] * i % p;
rfac[i] = 1LL * rfac[i-1] * (m - i + 1) % p ;
}
a[0][0] = 1;
for(int i=1;i<=5010;i++) {
for(int j=1;j<=i;j++) {
a[i][j] = (a[i-1][j-1] + 1LL * a[i-1][j] * (j-1) % p) % p;
}
}
int sum = 1;
int ans = 0;
for(int i=1;i<=n;i++) {
for(int j=1;j<=l[i];j++) {
dp[i][j] = 1LL * sum * rfac[j] % p * a[l[i]][j] % p;
if(i > 1 && j <= l[i-1]) {
dp[i][j] = (dp[i][j] - 1LL * dp[i-1][j] * a[l[i]][j] % p * fac[j] % p + p) % p;
}
ans = (ans + dp[i][j]) % p;
}
sum = ans;
ans = 0;
}
std::cout << sum << '\n';
return 0;
}

Codeforces Round #100 E. New Year Garland (第二类斯特林数+dp)的更多相关文章

  1. Codeforces 1528F - AmShZ Farm(转化+NTT+推式子+第二类斯特林数)

    Codeforces 题目传送门 & 洛谷题目传送门 神仙题,只不过感觉有点强行二合一(?). 首先考虑什么样的数组 \(a\) 符合条件,我们考虑一个贪心的思想,我们从前到后遍历,对于每一个 ...

  2. Codeforces 932 E Team Work ( 第二类斯特林数、下降阶乘幂、组合数学 )

    题目链接 题意 : 其实就是要求 分析 : 先暴力将次方通过第二类斯特林数转化成下降幂 ( 套路?) 然后再一步步化简.使得最外层和 N 有关的 ∑ 划掉 这里有个技巧就是 将组合数的表达式放到一边. ...

  3. codeforces 1278F - Cards(第二类斯特林数+二项式)

    传送门 解题过程: \(答案=\sum^n_{i=0}*C^i_n*{\frac{1}{m}}^i*{\frac{m-1}{m}}^{n-i}*i^k\) 根据第二类斯特林数的性质\(n^k=\sum ...

  4. 【CF961G】Partitions(第二类斯特林数)

    [CF961G]Partitions(第二类斯特林数) 题面 CodeForces 洛谷 题解 考虑每个数的贡献,显然每个数前面贡献的系数都是一样的. 枚举当前数所在的集合大小,所以前面的系数\(p\ ...

  5. HDU2643(SummerTrainingDay05-P 第二类斯特林数)

    Rank Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total Submis ...

  6. Gym Gym 101147G 第二类斯特林数

    题目链接:http://codeforces.com/gym/101147/problem/G 题意:n个人,去参加k个游戏,k个游戏必须非空,有多少种放法? 分析: 第二类斯特林数,划分好k个集合后 ...

  7. Gym - 101147G G - The Galactic Olympics —— 组合数学 - 第二类斯特林数

    题目链接:http://codeforces.com/gym/101147/problem/G G. The Galactic Olympics time limit per test 2.0 s m ...

  8. HDU2512 一卡通大冒险 —— 第二类斯特林数

    题目链接:https://vjudge.net/problem/HDU-2512 一卡通大冒险 Time Limit: 2000/1000 MS (Java/Others)    Memory Lim ...

  9. 【BZOJ5093】图的价值(第二类斯特林数,组合数学,NTT)

    [BZOJ5093]图的价值(第二类斯特林数,组合数学,NTT) 题面 BZOJ 题解 单独考虑每一个点的贡献: 因为不知道它连了几条边,所以枚举一下 \[\sum_{i=0}^{n-1}C_{n-1 ...

随机推荐

  1. 便捷编程-Xcode常用第三方插件 (随时更新)

    Xcode工具插件 1.XAlign 让Xcode编辑器中的代码以多种方式瞬间对齐 地址:https://github.com/qfish/XAlign 2.VVDocumenter-Xcode 在X ...

  2. wangEditor - 轻量级web富文本编辑器(可带图片上传)

    业务需求: 通过后台编辑文章和图片,上传到前端界面,展示新闻消息模块.这个时候,需要一款简洁的编辑器,百度编辑器是最常用的一种,但是功能太过于复杂,而wangEditor - 轻量级web富文本编辑器 ...

  3. 【Henu ACM Round#16 B】 Bear and Colors

    [链接] 我是链接,点我呀:) [题意] 在这里输入题意 [题解] O(n^2)枚举每一个区间. 然后维护这个区间里面的"统治数字"是什么. 对于每个区间cnt[统治数字]++; ...

  4. cogs 49. 跳马问题

    49. 跳马问题 ★   输入文件:horse.in   输出文件:horse.out   简单对比时间限制:1 s   内存限制:128 MB [问题描述] 有一只中国象棋中的 “ 马 ” ,在半张 ...

  5. 利用命令行删除Android系统自带应用的方法

    声明:本博客为原创博客.未经同意,不得转载!小伙伴们假设是在别的地方看到的话,建议还是来csdn上看吧(链接为http://blog.csdn.net/bettarwang/article/detai ...

  6. 如何实现对网站页面访问量的统计(javaweb和php)

    如何实现对网站页面访问量的统计(javaweb和php) 一.总结 一句话总结:其实很简单啦,每访问一次那个页面对应的index函数(控制器中的那个函数)访问次数就加1就可以了. 1.javaweb中 ...

  7. 初识Oracle中的正则表达式

    Oracle使用正则表达式离不开这4个函数: 1.regexp_like 2.regexp_substr 3.regexp_instr 4.regexp_replace  

  8. 2019.05.08 《Linux驱动开发入门与实战》

    第六章:字符设备 申请设备号---注册设备 1.字符设备的框架: 2.结构体,struct cdev: 3.字符设备的组成: 4.例子: 5.申请和释放设备号: 设备号和设备节点是什么关系.? 设备驱 ...

  9. 不固定高宽的 div 水平垂直居中

    <div class="father"> <div id="main"></div> </div> .fathe ...

  10. 【习题 8-1 UVA - 1149】Bin Packing

    [链接] 我是链接,点我呀:) [题意] 在这里输入题意 [题解] 每个背包只能装两个东西. 而且每个东西都要被装进去. 那么我们随意考虑某个物品.(不必要求顺序 这个物品肯定要放进某个背包里面的. ...