【BZOJ】4559: [JLoi2016]成绩比较 计数DP+排列组合+拉格朗日插值
【题意】n位同学(其中一位是B神),m门必修课,每门必修课的分数是[1,Ui]。B神碾压了k位同学(所有课分数<=B神),且第x门课有rx-1位同学的分数高于B神,求满足条件的分数情况数。当有一位同学的一门必修课分数不同时视为两种情况不同。n,m<=100,Ui<=10^9。
【算法】计数DP+排列组合+拉格朗日插值
【题解】把分数作为状态不现实,只能逐门课考虑。
设$f[i][j]$表示前i门课,有j个同学被碾压的情况数,则有:
$$f[i][j]=g(i)\cdot\sum_{k=j}^{n}f[i-1][k]\cdot\binom{k}{k-j}\cdot\binom{n-k-1}{r_i-1-k+j}$$
解释:首先可以发现当天分数需要高于B神的人数是确定的,和多少人被碾压等信息无关,所以令g(i)表示第i门课的合法分数情况数,独立计算。
枚举前i-1门课被碾压的人数k,那么ri-1由两部分组成,一部分是不再被碾压的k-j人(从k人中选出),剩余的ri-1-k+j人从原本就未被碾压的n-k-1人中选出。
考虑计算g(i),枚举B神的分数i,则有r-1人的选择范围是[i+1,Ui],另外n-r人的选择范围是[1,i],即:
$$g(i)=\sum_{i=1}^{U_i}(U_i-i)^{r_i-1}*i^{n-r}$$
Ui太大了,考虑将Ui当成自变量后用拉格朗日插值解决,即:
$$f(x)=\sum_{i=1}^{x}(x-i)^{r-1}*i^{n-r}$$
现在我们要求f(Ui)的值,需要确定多项式的次数。网上的解释都看不懂,强行理解:令i=x/2,那么式子右边的i也可以表示为(n-i),合并后次数为n-1,再加上Σ的上届为x,那么最高次就是n,这是一个n次多项式。
于是我们可以对每个i,O(n^2)枚举前n+1个点的值来插值得到f(Ui)。DP转移的复杂度也是O(n)的。
总复杂度O(n^3)。
#include<cstdio>
#include<algorithm>
using namespace std;
const int maxn=,MOD=1e9+;
int v[maxn],n,m,kind,u[maxn],r[maxn],g[maxn],f[maxn][maxn],c[maxn][maxn];
int power(int x,int k){int ans=;while(k){if(k&)ans=1ll*ans*x%MOD;x=1ll*x*x%MOD;k>>=;}return ans;}
int inv(int x){return power(x,MOD-);}
int M(int x){return x>=MOD?x-MOD:x;}
int solve(int u,int r){
for(int x=;x<=n+;x++){
g[x]=;//!
for(int i=;i<=x;i++){
g[x]=M(g[x]+1ll*power(x-i,r-)*power(i,n-r)%MOD);
}
if(x==u)return g[x];
}
for(int i=;i<=n+;i++){
v[i]=;
for(int j=;j<=n+;j++)if(i!=j)v[i]=1ll*v[i]*(i-j+MOD)%MOD;
v[i]=inv(v[i]);
}
int ans=;
for(int i=;i<=n+;i++){
int w=1ll*g[i]*v[i]%MOD;
for(int j=;j<=n+;j++)if(i!=j)w=1ll*w*(u-j+MOD)%MOD;//i!=j
ans=M(ans+w);
}
return ans;
}
int main(){
scanf("%d%d%d",&n,&m,&kind);
for(int i=;i<=n;i++){
c[i][]=;
for(int j=;j<=i;j++){
c[i][j]=M(c[i-][j-]+c[i-][j]);
}
}
for(int i=;i<=m;i++)scanf("%d",&u[i]);
for(int i=;i<=m;i++)scanf("%d",&r[i]);
f[][n-]=;
for(int i=;i<=m;i++){
int g=solve(u[i],r[i]);
for(int j=kind;j<=n;j++){
for(int k=j;k<=n;k++)if(r[i]--k+j>=&&r[i]--k+j<=n-k-){
f[i][j]=M(f[i][j]+1ll*f[i-][k]*c[k][k-j]%MOD*c[n-k-][r[i]--k+j]%MOD);
}
f[i][j]=1ll*f[i][j]*g%MOD;
}
}
printf("%d",f[m][kind]);
return ;
}
【BZOJ】4559: [JLoi2016]成绩比较 计数DP+排列组合+拉格朗日插值的更多相关文章
- 【BZOJ】2111: [ZJOI2010]Perm 排列计数 计数DP+排列组合+lucas
[题目]BZOJ 2111 [题意]求有多少1~n的排列,满足\(A_i>A_{\frac{i}{2}}\),输出对p取模的结果.\(n \leq 10^6,p \leq 10^9\),p是素数 ...
- bzoj 4559 [JLoi2016]成绩比较 —— DP+拉格朗日插值
题目:https://www.lydsy.com/JudgeOnline/problem.php?id=4559 看了看拉格朗日插值:http://www.cnblogs.com/ECJTUACM-8 ...
- BZOJ.4559.[JLOI2016]成绩比较(DP/容斥 拉格朗日插值)
BZOJ 洛谷 为什么已经9点了...我写了多久... 求方案数,考虑DP... \(f[i][j]\)表示到第\(i\)门课,还有\(j\)人会被碾压的方案数. 那么\[f[i][j]=\sum_{ ...
- ●BZOJ 4559 [JLoi2016]成绩比较
题链: http://www.lydsy.com/JudgeOnline/problem.php?id=4559 题解: 计数dp,拉格朗日插值法.真的是神题啊啊啊啊啊啊啊啊啊啊啊啊啊啊啊啊啊啊啊啊啊 ...
- bzoj 4559 [JLoi2016]成绩比较——拉格朗日插值
题目:https://www.lydsy.com/JudgeOnline/problem.php?id=4559 关于拉格朗日插值,可以看这些博客: https://www.cnblogs.com/E ...
- P3270 [JLOI2016]成绩比较 容斥 数论 组合数学 拉格朗日插值
LINK:成绩比较 大体思路不再赘述 这里只说几个我犯错的地方. 拉格朗日插值的时候 明明是n次多项式 我只带了n个值进去 导致一直GG. 拉格朗日插值的时候 由于是从1开始的 所以分母是\((i-1 ...
- ●BZOJ 4559 [JLoi2016]成绩比较(容斥)
题链: http://www.lydsy.com/JudgeOnline/problem.php?id=4559 题解: 容斥,拉格朗日插值法. 结合网上的另一种方法,以及插值法,可以把本题做到 O( ...
- G.subsequence 1(dp + 排列组合)
subsequence 1 时间限制:C/C++ 1秒,其他语言2秒 空间限制:C/C++ 262144K,其他语言524288K 64bit IO Format: %lld 题目描述 You are ...
- bzoj 3398 [Usaco2009 Feb]Bullcow 牡牛和牝牛——前缀和优化dp / 排列组合
题目:https://www.lydsy.com/JudgeOnline/problem.php?id=3398 好简单呀.而且是自己想出来的. dp[ i ]表示最后一个牡牛在 i 的方案数. 当前 ...
随机推荐
- Linux 压缩 解压缩 命令相关
1.命令格式:tar[必要参数][选择参数][文件] 2.命令功能:用来压缩和解压文件.tar本身不具有压缩功能.他是调用压缩功能实现的 3.命令参数:必要参数有如下:-A 新增压缩文件到已存在的压缩 ...
- Linux下更改正确国内时间
Linux使用小Tips 整理些Linux些常遇到的问题. Linux下设置时间 提供两种最根本有效的方式,就是更改时区.这里以更改为国内上海时间例子,其他地方时区同理. 方法一 备份文件 mv /e ...
- p2 碰撞
P2可以实现物体碰撞模拟,同时在碰撞过程中派发一些事件实现碰撞检测,将碰撞信息及时反馈,以添加相应的特效. P2中,当两个刚体的最小包围盒AABB发生重叠,碰撞就开始了:然后刚体的形状发生重叠,同时P ...
- YARN的重启动问题:RM Restart/RM HA/Timeline Server/NM Restart
ResourceManger Restart ResourceManager负责资源管理和应用的调度,是YARN的核心组件,有可能存在单点失败的问题.ResourceManager Restart是使 ...
- BZOJ5322 JXOI2018排序问题
对于一个序列,重排后有序的概率显然是∏cnti!/n!,其中cnti为第i种数出现次数.要使概率最小,显然应该让各种数字尽量平均分配.剩下的是div2BC左右的大讨论. #include<ios ...
- Cryptography Reloaded UVALive - 4353(BigInteger)
写写式子就出来了方程.. 然后解方程..不过数很大..用Java就好啦.. 就不贴呃的代码了...贴别人的..https://blog.csdn.net/qq_15714857/article/det ...
- debian8安装harbor
这里的系统版本是debian8.8,harbor版本为1.1.2. 1.安装docker-ce 1.1.Install packages to allow apt to use a repositor ...
- Android 65535 问题与 MultiDex分包
Android Multidex 遇到的问题 http://blog.csdn.net/wangbaochu/article/details/51178881 Android 使用android-su ...
- as, idea 出现 Gradle's dependency cache may be corrupt 错误分析
问题: Error:Failed to open zip file.Gradle's dependency cache may be corrupt (this sometimes occurs af ...
- 解题:POI 2011 Strongbox
首先洛谷的题面十分的劝退(至少对我这个菜鸡来说是这样),我来解释一下(原来的英文题面): 有一个有若干个密码(每个密码都可以开箱子)的密码箱,密码是在$0$到$n-1$的数中的,且所有的密码都满足一个 ...