题目

P4463 [国家集训队] calc

集训队的题目真是做不动呀\(\%>\_<\%\)

朴素方程

设\(f_{i,j}\)为前\(i\)个数值域\([1,j]\),且序列递增的总贡献,则有:

\[f_{i,j}=f_{i-1,j-1}*j+f{i,j-1}
\]

由于递增序列可以全排列的:\(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)\)次多项式,变式:

\[f_{i,j}-f(i,j-1)=f_{i-1,j-1}*j
\]

则有\(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(动规+拉格朗日插值法)的更多相关文章

  1. P4463 [国家集训队] calc(拉格朗日插值)

    传送门 设\(dp[i][j]\)为考虑\(i\)个数,其中最大值不超过\(j\)的答案,那么转移为\[dp[i][j]=dp[i-1][j-1]\times i\times j+dp[i][j-1] ...

  2. [国家集训队] calc

    嘟嘟嘟 这道题dp虽然不难,但是我还是没推出来,感觉最近脑子不太好用啊. 于是就跑去问神仙gjx(全国前三!)了.(外出集训真是好) 神仙不愧是神仙,一会儿就想出来了,而且方法还比网上的题解好懂. d ...

  3. 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!. 注意到值域很大,考 ...

  4. Luogu P4463 [国家集训队] calc

    WJMZBMR的题果然放在几年后看来仍然挺神,提出了一种独特的优化DP的方式 首先我们想一个暴力DP,先定下所有数的顺序(比如强制它递增),然后最后乘上\(n!\)种排列方式就是答案了 那么我们容易想 ...

  5. p4463 [国家集训队] calc

    分析 代码 #include<bits/stdc++.h> using namespace std; ][],Ans; inline int pw(int x,int p){ ; whil ...

  6. [BZOJ2655]calc(拉格朗日插值法+DP)

    2655: calc Time Limit: 30 Sec  Memory Limit: 512 MBSubmit: 428  Solved: 246[Submit][Status][Discuss] ...

  7. BZOJ2655 Calc - dp 拉格朗日插值法

    BZOJ2655 Calc 参考 题意: 给定n,m,mod,问在对mod取模的背景下,从[1,m]中选出n个数相乘可以得到的总和为多少. 思路: 首先可以发现dp方程 ,假定dp[m][n]表示从[ ...

  8. BZOJ 2038: [2009国家集训队]小Z的袜子(hose)

    2038: [2009国家集训队]小Z的袜子(hose) Time Limit: 20 Sec  Memory Limit: 259 MBSubmit: 7676  Solved: 3509[Subm ...

  9. bzoj2152 / P2634 [国家集训队]聪聪可可(点分治)

    P2634 [国家集训队]聪聪可可 淀粉质点分治板子 边权直接 mod 3 直接点分治统计出所有的符合条件的点对再和总方案数约分 至于约分.....gcd搞搞就好辣 #include<iostr ...

随机推荐

  1. js用计时器加载大量dom

    改进前: <table><tbody></tbody></table> var tbody=document.getElementsByTagName( ...

  2. 将socket5代理转换为http代理

    归根结底还是万恶的ZFW,MD弄得现在Google,gmail,dropbox都用不了了,看来这是要万民欢迎大中华局域网的到来了.最近在使用一同学的Shadowsocks来突破GFW的限制,可是电脑o ...

  3. Eclipse中的build path详解

    http://blog.csdn.net/qqqqqq654/article/details/53043742

  4. 一起talk C栗子吧(第二十五回:C语言实例--二分查找)

    各位看官们,大家好,上一回中咱们说的是顺序查找的样例,这一回咱们说的样例是:二分查找.闲话休 提,言归正转. 让我们一起talk C栗子吧. 看官们,我们在上一回中说了查找的相关内容,而且介绍了一种查 ...

  5. 【BZOJ4504】K个串 可持久化线段树+堆

    [BZOJ4504]K个串 Description 兔子们在玩k个串的游戏.首先,它们拿出了一个长度为n的数字序列,选出其中的一个连续子串,然后统计其子串中所有数字之和(注意这里重复出现的数字只被统计 ...

  6. UVAlive 7041 The Problem to Slow Down You(回文树)

    题目链接: https://icpcarchive.ecs.baylor.edu/index.php?option=com_onlinejudge&Itemid=8&page=show ...

  7. 相似性分析之Jaccard相似系数

    Jaccard, 又称为Jaccard相似系数(Jaccard similarity coefficient)用于比较有限样本集之间的相似性与差异性.Jaccard系数值越大,样本相似度越高 公式: ...

  8. MyEclipse中手工添加dtd支持

    1.先下载好相应的dtd文件,如struts-2.3.dtd 2.打开MyEclipse,Window->Preferences 在搜索框中输入"XML Catalog" 3 ...

  9. k8s更新Pod镜像

    实际使用k8s中,如果使用RC启动pod可以直接使用滚动更新进行pod版本的升级,但是我们使用的情况是在pod里面启动有状态的mysql服务,没有和RC进行关联,这样更新的时候只能通过 更新pod的配 ...

  10. delphi =------报错

    关于delphi软件运行出现Invalid floating point operation的错误的解决办法 关于delphi软件运行出现Invalid floating point operatio ...