[国家集训队] calc(动规+拉格朗日插值法)
题目
P4463 [国家集训队] calc
集训队的题目真是做不动呀\(\%>\_<\%\)
朴素方程
设\(f_{i,j}\)为前\(i\)个数值域\([1,j]\),且序列递增的总贡献,则有:
\]
由于递增序列可以全排列的:\(ans=f_{n,A}×n!\)
时间复杂度\(O(nA)\)
证明一
设\(f_{i,j}\)为关于\(j\)的\(2i\)次多项式,则\(f_{i-1,j-1}*j\)为关于\(j\)的2i-1次多项式,\(f_{i,j-1}\)为关于\(j\)的\(2i\)次多项式
通过归纳法证明出\(f_{i,j}\)为关于\(j\)的\(2i\)次多项式
证明二
设\(f_{i,j}\)为关于\(j\)的\(g(i)\)次多项式,变式:
\]
则有\(g(i)-1=g(i-1)+1\longrightarrow g(i)=g(i-1)+2\),故\(f_{i,j}\)为关于\(j\)的\(2i\)次多项式
具体做法
综上我们已经证明出了\(f_{i,j}\)为关于\(j\)的\(2i\)次多项式,所以仅需\(2i\)项,通过拉格朗日插值法就能得出这个多项式的系数表示法,从而代入\(j=A\)求解即可
而\((i,f_{n,i})\),就相当于多项式在坐标系上的一点,我们需要求出\(2n+1\)个点去确定多项式\(k_0~k_{2n}\)这些系数
Code
#include<bits/stdc++.h>
typedef int LL;
const LL maxn=2e3;
LL A,n,mod,N;
LL y[maxn],f[maxn][maxn];
inline LL Pow(LL base,LL b){
LL ret(1);
while(b){
if(b&1) ret=1ll*ret*base%mod; base=1ll*base*base%mod; b>>=1;
}return ret;
}
inline LL Calc(LL x){
LL ret(0);
for(LL i=1;i<=N;++i){
LL p(y[i]),q(1);
for(LL j=1;j<=N;++j){
if(j!=i){
p=1ll*p*(x-j+mod)%mod;
q=1ll*q*(i-j+mod)%mod;
}
}
ret=(ret+1ll*p*Pow(q,mod-2)%mod)%mod;
}
return ret;
}
int main(){
scanf("%d%d%d",&A,&n,&mod);
N=(n<<1)+1;
for(LL i=0;i<=N;++i) f[0][i]=1;
for(LL i=1;i<=n;++i)
for(LL j=1;j<=N;++j)
f[i][j]=(1ll*f[i-1][j-1]*j%mod+f[i][j-1])%mod;
LL C(1);
for(LL i=2;i<=n;++i) C=1ll*C*i%mod;
for(LL i=1;i<=N;++i) y[i]=f[n][i];
if(A<=N)
printf("%d",1ll*f[n][A]*C%mod);
else
printf("%d",1ll*Calc(A)*C%mod);
return 0;
}
[国家集训队] calc(动规+拉格朗日插值法)的更多相关文章
- P4463 [国家集训队] calc(拉格朗日插值)
传送门 设\(dp[i][j]\)为考虑\(i\)个数,其中最大值不超过\(j\)的答案,那么转移为\[dp[i][j]=dp[i-1][j-1]\times i\times j+dp[i][j-1] ...
- [国家集训队] calc
嘟嘟嘟 这道题dp虽然不难,但是我还是没推出来,感觉最近脑子不太好用啊. 于是就跑去问神仙gjx(全国前三!)了.(外出集训真是好) 神仙不愧是神仙,一会儿就想出来了,而且方法还比网上的题解好懂. d ...
- BZOJ2655 calc(动态规划+拉格朗日插值法)
考虑暴力dp:f[i][j]表示i个数值域1~j时的答案.考虑使其值域++,则有f[i][j]=f[i][j-1]+f[i-1][j-1]*i*j,边界f[i][i]=i!*i!. 注意到值域很大,考 ...
- Luogu P4463 [国家集训队] calc
WJMZBMR的题果然放在几年后看来仍然挺神,提出了一种独特的优化DP的方式 首先我们想一个暴力DP,先定下所有数的顺序(比如强制它递增),然后最后乘上\(n!\)种排列方式就是答案了 那么我们容易想 ...
- p4463 [国家集训队] calc
分析 代码 #include<bits/stdc++.h> using namespace std; ][],Ans; inline int pw(int x,int p){ ; whil ...
- [BZOJ2655]calc(拉格朗日插值法+DP)
2655: calc Time Limit: 30 Sec Memory Limit: 512 MBSubmit: 428 Solved: 246[Submit][Status][Discuss] ...
- BZOJ2655 Calc - dp 拉格朗日插值法
BZOJ2655 Calc 参考 题意: 给定n,m,mod,问在对mod取模的背景下,从[1,m]中选出n个数相乘可以得到的总和为多少. 思路: 首先可以发现dp方程 ,假定dp[m][n]表示从[ ...
- BZOJ 2038: [2009国家集训队]小Z的袜子(hose)
2038: [2009国家集训队]小Z的袜子(hose) Time Limit: 20 Sec Memory Limit: 259 MBSubmit: 7676 Solved: 3509[Subm ...
- bzoj2152 / P2634 [国家集训队]聪聪可可(点分治)
P2634 [国家集训队]聪聪可可 淀粉质点分治板子 边权直接 mod 3 直接点分治统计出所有的符合条件的点对再和总方案数约分 至于约分.....gcd搞搞就好辣 #include<iostr ...
随机推荐
- js用计时器加载大量dom
改进前: <table><tbody></tbody></table> var tbody=document.getElementsByTagName( ...
- 将socket5代理转换为http代理
归根结底还是万恶的ZFW,MD弄得现在Google,gmail,dropbox都用不了了,看来这是要万民欢迎大中华局域网的到来了.最近在使用一同学的Shadowsocks来突破GFW的限制,可是电脑o ...
- Eclipse中的build path详解
http://blog.csdn.net/qqqqqq654/article/details/53043742
- 一起talk C栗子吧(第二十五回:C语言实例--二分查找)
各位看官们,大家好,上一回中咱们说的是顺序查找的样例,这一回咱们说的样例是:二分查找.闲话休 提,言归正转. 让我们一起talk C栗子吧. 看官们,我们在上一回中说了查找的相关内容,而且介绍了一种查 ...
- 【BZOJ4504】K个串 可持久化线段树+堆
[BZOJ4504]K个串 Description 兔子们在玩k个串的游戏.首先,它们拿出了一个长度为n的数字序列,选出其中的一个连续子串,然后统计其子串中所有数字之和(注意这里重复出现的数字只被统计 ...
- UVAlive 7041 The Problem to Slow Down You(回文树)
题目链接: https://icpcarchive.ecs.baylor.edu/index.php?option=com_onlinejudge&Itemid=8&page=show ...
- 相似性分析之Jaccard相似系数
Jaccard, 又称为Jaccard相似系数(Jaccard similarity coefficient)用于比较有限样本集之间的相似性与差异性.Jaccard系数值越大,样本相似度越高 公式: ...
- MyEclipse中手工添加dtd支持
1.先下载好相应的dtd文件,如struts-2.3.dtd 2.打开MyEclipse,Window->Preferences 在搜索框中输入"XML Catalog" 3 ...
- k8s更新Pod镜像
实际使用k8s中,如果使用RC启动pod可以直接使用滚动更新进行pod版本的升级,但是我们使用的情况是在pod里面启动有状态的mysql服务,没有和RC进行关联,这样更新的时候只能通过 更新pod的配 ...
- delphi =------报错
关于delphi软件运行出现Invalid floating point operation的错误的解决办法 关于delphi软件运行出现Invalid floating point operatio ...