LINK:Number of Binominal Coefficients

原来难题都长这样。。

水平有限只能推到一半。

设\(f(x)\)表示x中所含p的最大次数。即x质因数分解之后 p的指标。

容易想到 \(f(n!)=\sum_{i=1}^{n}\frac{n}{p^i}\)

也同时 题目其实是想让我们求出 \(f(n!)-f(k!)-f((n-k)!)>=a\)的数对(n,k)的个数。

需要再转换一下 可以得到\(f(x)\)x质因数分解之后扔掉第一位的数字大小。

\(f(n!)\)其实是 不断扔掉一位 数字大小的累加。

但是我们需要求出\(f(C(n,k))\) 这里可以自己硬猜 不过存在一个库默尔定理。

\(f(C(n,k))\)其实是 \(f(n!)-f(k!)-(n-k)!\)也即 k和n-k在p进制下进位的次数。

这里给出简单证明:如果不存在进位 那么显然 这个东西就是为0.

如果某一位存在进位 那么在统计当前位的时候没有影响 统计下一位的贡献时 \(f(n!)\)会多1.

显然当前的进位只会对下一位有贡献1。

也就是每次进位都是n!比k!+(n-k)!多1的时候 所以\(f(C(n,k))\)即 k和n-k在p进制下进位的次数。

至此 可以发现需要解决的问题变成了 有多少个数对(n,k) 在p进制下进位次数>=a 当然\(n+k\leq lim\)

剩下的 就是一个数位dp的模型了 不过有点难写。

大体上 设状态 f[i][j][0/1][0/1]表示最高位~当前位 有j次进位 且是否存在最高位限制 且是否有下一位的进位。

值得一提的是需要保留下一位是否进位 而并非当前位 因为下一位对当前有影响 且一下位也同时影响着 当前位是否满足限制。

记忆化搜索就不大行了 常数大了 这个状态被定义出来就是接近1e7的。

显然递推需要从 左到右推 转移比较难写 注意要认真。

这可真是 从头到尾都是一道难题该有的样子。

const int MAXN=3510;
int n,m,p,a;
int f[MAXN][MAXN][2][2];//f[i][j][k][l]表示n~i+1位进了j次位了有没有最高位的限制是否存对上一次的进位.
char c[MAXN];
int cc[MAXN],b[MAXN];
int main()
{
freopen("1.in","r",stdin);
gt(p);gt(a);gc(c);
m=strlen(c+1);
reverse(c+1,c+1+m);
rep(1,m,i)cc[i]=c[i]-'0';
while(m)
{
ll cnt=0;
fep(m,1,i)
{
cnt=cnt*10+cc[i];
cc[i]=cnt/p;cnt%=p;
}
if(!cc[m]&&m>=1)--m;
b[++n]=cnt;
}
if(a>n-1){puts("0");return 0;}
f[n+1][0][1][0]=1;
fep(n,1,i)
{
int c0=(ll)(1+p)*p/2%mod;//定义域为[0,p-1]值域为[0,p-1].
int c1=(ll)(b[i]+1)*b[i]/2%mod;//定义域为[a+b<=bi-1] 值域为[0,bi-1].
int c2=(ll)(p-1)*p/2%mod;//定义域为[0,p-1] 值域为[p,2p-2]
int c3=(ll)b[i]*(2*p-b[i]-1)/2%mod;//定义域为[a+b<=p+bi-1] 值域[p,p+bi-1]
int c4=(ll)(b[i]-1)*b[i]/2%mod;
int c5=(ll)(2*p-b[i]+1)*b[i]/2%mod;
rep(0,n-i,j)
{
int f0=f[i+1][j][0][0],f1=f[i+1][j][1][0];
int f2=f[i+1][j][0][1],f3=f[i+1][j][1][1];
f[i][j][0][0]=((ll)f0*c0%mod+(ll)c1*f1+(ll)f2*c2%mod+(ll)f3*c3%mod)%mod;
f[i][j][1][0]=((ll)(b[i]+1)*f1%mod+(ll)(p-1-b[i])*f3%mod)%mod;
f[i][j+1][0][1]=((ll)c2*f0%mod+(ll)c4*f1%mod+(ll)c0*f2%mod+(ll)c5*f3%mod)%mod;
f[i][j+1][1][1]=((ll)b[i]*f1%mod+(ll)(p-b[i])*f3%mod)%mod;
}
}
ll ans=0;
rep(a,n,i)
{
ans=(ans+f[1][i][0][0]+f[1][i][1][0])%mod;
//cout<<f[1][i][0][0]<<endl;
}
putl(ans);return 0;
}

CF582D Number of Binominal Coefficients 库默尔定理 数位dp的更多相关文章

  1. [CSP-S模拟测试]:密码(数位DP+库默尔定理)

    题目描述 为了揭穿$SERN$的阴谋,$Itaru$黑进了$SERN$的网络系统.然而,想要完全控制$SERN$,还需要知道管理员密码.$Itaru$从截获的信息中发现,$SERN$的管理员密码是两个 ...

  2. Codeforces 582D - Number of Binominal Coefficients(Kummer 定理+数位 dp)

    Codeforces 题目传送门 & 洛谷题目传送门 一道数论与数位 dp 结合的神题 %%% 首先在做这道题之前你需要知道一个定理:对于质数 \(p\) 及 \(n,k\),最大的满足 \( ...

  3. hdu 5898 odd-even number 数位DP

    传送门:hdu 5898 odd-even number 思路:数位DP,套着数位DP的模板搞一发就可以了不过要注意前导0的处理,dp[pos][pre][status][ze] pos:当前处理的位 ...

  4. codeforces Hill Number 数位dp

    http://www.codeforces.com/gym/100827/attachments Hill Number Time Limits:  5000 MS   Memory Limits: ...

  5. HDU 5787 K-wolf Number 数位DP

    K-wolf Number Problem Description   Alice thinks an integer x is a K-wolf number, if every K adjacen ...

  6. Fzu2109 Mountain Number 数位dp

    Accept: 189    Submit: 461Time Limit: 1000 mSec    Memory Limit : 32768 KB  Problem Description One ...

  7. HDU 3709 Balanced Number (数位DP)

    Balanced Number Time Limit: 10000/5000 MS (Java/Others)    Memory Limit: 65535/65535 K (Java/Others) ...

  8. HDU3709 Balanced Number (数位dp)

     Balanced Number Time Limit:3000MS     Memory Limit:0KB     64bit IO Format:%lld & %llu Descript ...

  9. 多校5 HDU5787 K-wolf Number 数位DP

    // 多校5 HDU5787 K-wolf Number 数位DP // dp[pos][a][b][c][d][f] 当前在pos,前四个数分别是a b c d // f 用作标记,当现在枚举的数小 ...

随机推荐

  1. 机器学习实战基础(十八):sklearn中的数据预处理和特征工程(十一)特征选择 之 Wrapper包装法

    Wrapper包装法 包装法也是一个特征选择和算法训练同时进行的方法,与嵌入法十分相似,它也是依赖于算法自身的选择,比如coef_属性或feature_importances_属性来完成特征选择.但不 ...

  2. 数据可视化之DAX篇(二)Power BI中的度量值和计算列,你搞清楚了吗?

    https://zhuanlan.zhihu.com/p/75462046 对于初学者,总是会把度量值和计算列搞混,我也经常碰到这样的问题,有些星友用文章中的代码总是报错,发给我一看,才知道TA把本来 ...

  3. vue axios接口封装、Promise封装、简单的axios方法封装、vue接口方法封装、vue post、get、patch、put方法封装

    相信大家在做前后端数据交互的时候都会给请求做一些简单的封装就像之前封装ajax方法一样axios的封装也是一样的简单下面这个就是封装的axios的方法,require.js import axios ...

  4. [Qt插件]-03创建Qt Designer自定义部件

    如何创建自定义部件并添加到Qt Designer来爽快的拖动部件可视化界面设计?   Qt Designer基于插件的架构使得它可以使用用户设计或者第三方提供的自定义部件,就像使用标准的Qt部件一样. ...

  5. 【真实分享】学习linux!让我工资翻5倍!从月薪3000到年薪18W!只用了六个月!

    月薪3000到年薪18W,我用了六个月时间.从只会皮毛,到一家公司的运维工程师主力,我的故事蛮神奇的,今天和大家分享一下我自己的经历. 我今年26岁,之前做个体,修过电脑,卖过电脑,做过桌面运维,一直 ...

  6. 最小割树(Gomory-Hu Tree)

    当我们遇到这样的问题: 给定一个 \(n\) 个点 \(m\) 条边的无向连通图,多次询问两点之间的最小割 我们通常要用到最小割树. 博客 建树 分治.记录当前点集,然后随便找俩点当 \(s\) 和 ...

  7. 坚果云如何使用二次验证码/谷歌身份验证器/两步验证/虚拟MFA?

    一般步骤:登陆后点邮箱名——安全设置——开通两步验证,用二次验证码微信小程序绑定即可 具体步骤见链接  坚果云如何使用二次验证码/谷歌身份验证器/两步验证/虚拟MFA? 二次验证码小程序于谷歌身份验证 ...

  8. MVC + EFCore 项目实战 - 数仓管理系统7 - 数据源管理中--新增数据源

    上篇我们完成了数据源列表展示功能(还未测试). 本篇我们来新增数据源,并查看列表展示功能.   接上篇: 二.数据源管理功能开发 2.新增数据源 我们用模态对话框来完成数据源的新增,效果如下图: 我们 ...

  9. mybatis sqlsession与sqlsquery、transaction、connection

    sqlsession和connection 一个sqlsession一般对应一个connection,并且mybatis默认每次获取session都会开启一个事务,且不自动提交事务.如果更新操作完成后 ...

  10. jmeter之断言、数据提取器(正则表达式、jsonpath、beanshell)、聚合报告、参数化

    ctx - ( JMeterContext) - gives access to the context vars - ( JMeterVariables) - gives read/write ac ...