题目

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. mui 单页面下拉刷新

    <!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title> ...

  2. iOS开发之 -- oc和swift下输出乘法口诀表

    闲来无事,写着玩: oc: //乘法口诀表输出 ; i<=; i++) { ; j<=i; j++) { NSLog(@"%dx%d=%d\n",i,j,i*j); } ...

  3. iOS开发之--Mac终端命令大全

    目录操作 命令名 功能描述 使用举例 mkdir 创建一个目录 mkdir dirname rmdir 删除一个目录 rmdir dirname mvdir 移动或重命名一个目录 mvdir dir1 ...

  4. 初步了解 cURL

    今天需要用PHP模拟post请求,查了查资料,了解到cURL.看了一篇博客,写的很详细,就转载了,与大家分享.[原文链接] 什么是cURL?可能还有很多同学没有听说过这个工具,我先来给大家简单介绍下什 ...

  5. python 解析 XML文件

    如下使用xml.etree.ElementTree模块来解析XML文件.ElementTree模块中提供了两个类用来完成这个目的: ElementTree表示整个XML文件(一个树形结构) Eleme ...

  6. linux时间格式化

    echo `date +'[%Y-%m-%d %H:%M:%S]'`

  7. Parrot Linux国内源

    China USTC (University of Science and Technology of China and USTCLUG) - Hefei University 1 Gbps for ...

  8. 穿透Session 0 隔离(一)

    服务(Service)对于大家来说一定不会陌生,它是Windows 操作系统重要的组成部分.我们可以把服务想像成一种特殊的应用程序,它随系统的“开启-关闭”而“开始-停止”其工作内容,在这期间无需任何 ...

  9. MySQL 索引设计概要

    在关系型数据库中设计索引其实并不是复杂的事情,很多开发者都觉得设计索引能够提升数据库的性能,相关的知识一定非常复杂. 然而这种想法是不正确的,索引其实并不是一个多么高深莫测的东西,只要我们掌握一定的方 ...

  10. Spoken English Practice(Look, That cute guy is checking me out. come on, give me a break, he's just looking around.)

    绿色:连读:                  红色:略读:               蓝色:浊化:               橙色:弱读     下划线_为浊化 口语蜕变(2017/7/6) 英 ...