题意

[省选联考 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 卷] 组合数问题的更多相关文章

  1. luoguP6620 [省选联考 2020 A 卷] 组合数问题(斯特林数)

    luoguP6620 [省选联考 2020 A 卷] 组合数问题(斯特林数) Luogu 题外话: LN切这题的人比切T1的多. 我都想到了组合意义乱搞也想到可能用斯特林数为啥还是没做出来... 我怕 ...

  2. [题解] LOJ 3300 洛谷 P6620 [省选联考 2020 A 卷] 组合数问题 数学,第二类斯特林数,下降幂

    题目 题目里要求的是: \[\sum_{k=0}^n f(k) \times X^k \times \binom nk \] 这里面出现了给定的多项式,还有组合数,这种题目的套路就是先把给定的普通多项 ...

  3. luoguP6623 [省选联考 2020 A 卷] 树(trie树)

    luoguP6623 [省选联考 2020 A 卷] 树(trie树) Luogu 题外话: ...想不出来啥好说的了. 我认识的人基本都切这道题了. 就我只会10分暴力. 我是傻逼. 题解时间 先不 ...

  4. luoguP6624 [省选联考 2020 A 卷] 作业题(莫比乌斯反演,矩阵树定理)

    luoguP6624 [省选联考 2020 A 卷] 作业题(莫比乌斯反演,矩阵树定理) Luogu 题外话: Day2一题没切. 我是傻逼. 题解时间 某种意义上说刻在DNA里的柿子,大概是很多人学 ...

  5. 洛谷P6623——[省选联考 2020 A 卷] 树

    传送门:QAQQAQ 题意:自己看 思路:正解应该是线段树/trie树合并? 但是本蒟蒻啥也不会,就用了树上二次差分 (思路来源于https://www.luogu.com.cn/blog/dengy ...

  6. P6628-[省选联考 2020 B 卷] 丁香之路【欧拉回路,最小生成树】

    正题 题目链接:https://www.luogu.com.cn/problem/P6628 题目大意 给出\(n\)个点的一张完全无向图,\(i\sim j\)的边权是\(|i-j|\). 然后给出 ...

  7. 洛谷 P6624 - [省选联考 2020 A 卷] 作业题(矩阵树定理+简单数论)

    题面传送门 u1s1 这种题目还是相当套路的罢 首先看到 \(\gcd\) 可以套路地往数论方向想,我们记 \(f_i\) 为满足边权的 \(\gcd\) 为 \(i\) 的倍数的所有生成树的权值之和 ...

  8. 题解 P6622 [省选联考 2020 A/B 卷] 信号传递

    洛谷 P6622 [省选联考 2020 A/B 卷] 信号传递 题解 某次模拟赛的T2,考场上懒得想正解 (其实是不会QAQ), 打了个暴力就骗了\(30pts\) 就火速溜了,参考了一下某位强者的题 ...

  9. luoguP6622 [省选联考 2020 A/B 卷] 信号传递(状压dp)

    luoguP6622 [省选联考 2020 A/B 卷] 信号传递(状压dp) Luogu 题外话: 我可能是傻逼, 但不管我是不是傻逼, 我永远单挑出题人. 题解时间 看数据范围可以确定状压dp. ...

随机推荐

  1. 小白自制Linux开发板 六. SPI TFT屏幕修改与移植

    本文章参考:https://www.bilibili.com/read/cv9947785?spm_id_from=333.999.0.0 本篇通过SPI接口,使用ST7789V TFT焊接屏(13p ...

  2. 【UE4 C++】Tick的三种方式、异步蓝图节点

    Tick的三种方式 包括 默认 Tick (Actor.Component.UMG) TimerManager 定时器 FTickableGameObject 可以写原生 Object 也可以继承UO ...

  3. Noip模拟45 2021.8.21

    一定别删大括号,检查是;还是, ceil函数里面要写double,否则根本没用!!!!!!! T1 打表 正解:打表 考场上很难真正把柿子理解着推出来 况且想要理解题意就很难,比如我就理解错了 半猜着 ...

  4. 热身训练1 Problem B. Harvest of Apples

    http://acm.hdu.edu.cn/showproblem.php?pid=6333 题意: 求 C(0,n)+C(1,n)+...+C(m,n) 分析: 这道题,我们令s(m,n) = C( ...

  5. QEvent

    QEvent类是所有事件类的基类,每一个对象都包含事件参数.Qt的主事件循环(QCoreApplication::exec())从事件队列中接收本地窗口系统的事件,并将它们翻译成QEvent,将这些事 ...

  6. [LGP1866]编号

    传送门 题意:找n个数,使得 $ 1 \leq a_i \leq Maxnumber_i $ 求有多少种组合 这题我们可以看到,还有一种无解的情况 我们可以先判断无解的情况 首先把Maxnumber数 ...

  7. Xpath运算符

    5.position定位 >>print tree.xpath('//*[@id="testid"]/ol/li[position()=2]/text()')[0] & ...

  8. 开发笔记-----Ajax 基础使用

    一.GET 方式的用法: 1 <!--html --> 2 <div class="layui-form"> 3 <div class="l ...

  9. Linux常用命令和快捷键整理:(2)常用快捷键

    前言: Linux常用快捷键和基本命令整理,先上思维导图: linux常用命令请见:https://www.cnblogs.com/yinzuopu/p/15516499.html 基本快捷键的使用 ...

  10. 【Python+postman接口自动化测试】(5)抓包工具Fiddler简介

    Fiddler简介 Fiddler 4.6 下载 http://www.downza.cn/soft/234727.html 为什么使用Fiddler? 可以抓到请求数据,查看Raw格式/表单格式/J ...