[省选联考 2020 A 卷] 组合数问题
题意
想法
自己在多项式和数论方面还是太差了,最近写这些题都没多少思路,看完题解才会
首先有这两个柿子
\(k*\dbinom{n}{k} = n*\dbinom{n - 1}{k - 1}\)
\((1 + x) ^ n = \sum_{i = 0}^{n}\dbinom{n}{i}x^i\)
然后对于题目中所要求的多项式\(f(x)\)我们自然把他拆开,对于一个单个\(k\)对答案贡献
\(\sum_{i = 1}^{m}a_i * (k^i * x^k * \dbinom{n}{k})\)
然后我们发现这个项\(k^i* \dbinom{n}{k}\)
是我们所给的第一个柿子的拓展
我们取\(i = 2\)来看看柿子的展开
\(k^2* \dbinom{n}{k}\)
\(k*((n) * \dbinom{n - 1}{k - 1})\)
\((k - 1 + 1)*((n) * \dbinom{n - 1}{k - 1})\)
\((k - 1)*n*\dbinom{n - 1}{k - 1} + n * \dbinom{n - 1}{k - 1}\)
\(n*(n - 1)*\dbinom{n - 2}{k - 2} + n * \dbinom{n - 1}{k - 1}\)
取\(i = 3.......\)
我们发现\(k^p * \dbinom{n}{k}\)
可以变为这个柿子
\(\sum_{i = 1}^pS(p,i)n^{\underline i}\dbinom{n - i}{k - i}\)
其中\(n^{\underline i}\)是下降幂
而\(S(p,i)\)这个系数可以这样推来\(S(p,i) = i * S(p - 1,i) + S(p - 1,i - 1)\)
当你在计算展开的时候我们注意到如果我们先把\(k\)给乘进去可以很自然的把一些柿子给转化成\(k^i-1\dbinom{n}{k}\)的展开形式
这个时候会给\(S(p,i)多一个S(p - 1,i - 1)的系数\)
然后我们会发现把可转化的柿子转化完后\(我们把k拆成(k - i + i)这个时候又会多一个i * S(p - 1,i)\)
这是一个好的结论
\(k^p * \dbinom{n}{k}\ =\ \sum_{i = 1}^pS(p,i)n^{\underline i}\dbinom{n - i}{k - i}\)
其中
\(S(p,i) = i * S(p - 1,i) + S(p - 1,i - 1)\)
然后我们往原柿子里带(打不动了)

括号里用二项式定理打开

做完了

代码
#include <cstdio>
using namespace std;
typedef long long LL;
inline LL read()
{
LL val = 0; char c = getchar();
while(c < '0' || c > '9') c = getchar();
while(c >= '0' && c <= '9') { val = val * 10 + (c ^ 48); c = getchar(); }
return val;
}
const int M = 1005;
LL a[M], n, x, p, m, S[M][M], ans;
inline LL Qpow(LL b, LL c)
{
LL res = 1;
while(c)
{
if(c & 1) res = res * b % p;
b = b * b % p;
c >>= 1;
}
return res;
}
int main()
{
n = read(); x = read(); p = read(); m = read();
for(int i = 0; i <= m; i++) a[i] = read();
S[1][1] = 1;
for(int i = 2; i <= m; i++)
for(int j = 1; j <= i; j++)
S[i][j] = ((S[i - 1][j] * j) % p + S[i - 1][j - 1]) % p;
ans = a[0] * Qpow(x + 1, n) % p;
for(int i = 1; i <= m; i++)
{
LL sum = 0, tmp = n;
for(int j = 1; j <= i; j++)
{
sum = (sum + (S[i][j] * tmp % p * Qpow(x, j) % p * Qpow(x + 1, n - j) % p)) % p;
tmp = tmp * (n - j) % p;
}
ans = (ans + a[i] * sum % p) % p;
}
printf("%lld\n", ans);
return 0;
}
[省选联考 2020 A 卷] 组合数问题的更多相关文章
- luoguP6620 [省选联考 2020 A 卷] 组合数问题(斯特林数)
luoguP6620 [省选联考 2020 A 卷] 组合数问题(斯特林数) Luogu 题外话: LN切这题的人比切T1的多. 我都想到了组合意义乱搞也想到可能用斯特林数为啥还是没做出来... 我怕 ...
- [题解] LOJ 3300 洛谷 P6620 [省选联考 2020 A 卷] 组合数问题 数学,第二类斯特林数,下降幂
题目 题目里要求的是: \[\sum_{k=0}^n f(k) \times X^k \times \binom nk \] 这里面出现了给定的多项式,还有组合数,这种题目的套路就是先把给定的普通多项 ...
- luoguP6623 [省选联考 2020 A 卷] 树(trie树)
luoguP6623 [省选联考 2020 A 卷] 树(trie树) Luogu 题外话: ...想不出来啥好说的了. 我认识的人基本都切这道题了. 就我只会10分暴力. 我是傻逼. 题解时间 先不 ...
- luoguP6624 [省选联考 2020 A 卷] 作业题(莫比乌斯反演,矩阵树定理)
luoguP6624 [省选联考 2020 A 卷] 作业题(莫比乌斯反演,矩阵树定理) Luogu 题外话: Day2一题没切. 我是傻逼. 题解时间 某种意义上说刻在DNA里的柿子,大概是很多人学 ...
- 洛谷P6623——[省选联考 2020 A 卷] 树
传送门:QAQQAQ 题意:自己看 思路:正解应该是线段树/trie树合并? 但是本蒟蒻啥也不会,就用了树上二次差分 (思路来源于https://www.luogu.com.cn/blog/dengy ...
- P6628-[省选联考 2020 B 卷] 丁香之路【欧拉回路,最小生成树】
正题 题目链接:https://www.luogu.com.cn/problem/P6628 题目大意 给出\(n\)个点的一张完全无向图,\(i\sim j\)的边权是\(|i-j|\). 然后给出 ...
- 洛谷 P6624 - [省选联考 2020 A 卷] 作业题(矩阵树定理+简单数论)
题面传送门 u1s1 这种题目还是相当套路的罢 首先看到 \(\gcd\) 可以套路地往数论方向想,我们记 \(f_i\) 为满足边权的 \(\gcd\) 为 \(i\) 的倍数的所有生成树的权值之和 ...
- 题解 P6622 [省选联考 2020 A/B 卷] 信号传递
洛谷 P6622 [省选联考 2020 A/B 卷] 信号传递 题解 某次模拟赛的T2,考场上懒得想正解 (其实是不会QAQ), 打了个暴力就骗了\(30pts\) 就火速溜了,参考了一下某位强者的题 ...
- luoguP6622 [省选联考 2020 A/B 卷] 信号传递(状压dp)
luoguP6622 [省选联考 2020 A/B 卷] 信号传递(状压dp) Luogu 题外话: 我可能是傻逼, 但不管我是不是傻逼, 我永远单挑出题人. 题解时间 看数据范围可以确定状压dp. ...
随机推荐
- BUAA 软工 结对项目作业
1.相关信息 Q A 这个作业属于哪个课程 2020春季计算机学院软件工程(罗杰 任健) 这个作业的要求在哪里 结对项目作业 我在这个课程的目标是 系统地学习软件工程开发知识,掌握相关流程和技术,提升 ...
- python pip whl安装和使用
转载:https://www.cnblogs.com/klb561/p/9271322.html 1 python的安装 首先,从python的官方网站 www.python.org下载需要的pyth ...
- js-arguments 函数参数对象详解
前言 JavaScript 函数参数不同于其他编程语言,既不需要规定参数的类型,也不需要关心参数的个数,因此 JavaScript 因函数参数而变得十分灵活,本文总结一下 arguments 参数对象 ...
- Vulnstack内网靶场4
环境 漏洞详情 (qiyuanxuetang.net) 仅主机模式内网网段192.168.183.0/24 外网网段192.168.157.0/24 其中Ubuntu作为对外的内网机器 攻击机kali ...
- pip切换源
pip国内的一些镜像 阿里云http://mirrors.aliyun.com/pypi/simple/ 中国科技大学https://pypi.mirrors.ustc.edu.cn/simple/ ...
- Qt5 C++ GUI界面 开发环境配置 详细教程
本博客已暂停更新,需要请转新博客http://www.whbwiki.com/333.html Qt 下载 Qt 体积很大,有 1GB~3GB,官方下载通道非常慢,相信很多读者会崩溃,所以建议大家使用 ...
- 体验webhooks
一.webhooks是什么 webhooks是一种实现在web api跟web service之间的发布订阅的轻量级的模式:当服务中心某个事件发生的时候,就会向订阅者发送一个POST请求形式的通知,这 ...
- Part 18 $http service in AngularJS
In Angular there are several built in services. $http service is one of them. In this video, we will ...
- 暑假算法练习Day6
最近开始了实验室的生活,并且学习了bullet journal.希望接下来的每一天都能完成所有的任务. 1012 数字分类 (20 分) 给定一系列正整数,请按要求对数字进行分类,并输出以下 5 个数 ...
- Java 多线程 - 总结概述
概述 菜鸟教程: Java 给多线程编程提供了内置的支持. 一条线程指的是进程中一个单一顺序的控制流,一个进程中可以并发多个线程,每条线程并行执行不同的任务. 多线程是多任务的一种特别的形式,但多线程 ...