CS Academy Sliding Product Sum(组合数)
题意
有一个长为 \(N\) 的序列 \(A = [1, 2, 3, \dots, N]\) ,求所有长度 \(\le K\) 的子串权值积的和,对于 \(M\) 取模。
\(N \le 10^{18}, K \le \min(600, n), M \le 10^{18}\)
题解
一道还有些意思的组合数学题 qwq
一开始觉得这不是 \(K\) 次多项式么,直接插值QAQ 发现模数不给,逆元可能都没有,太不友好啦。
令 \(ans_k\) 为长度为 \(k\) 的子串的贡献和。其实我们就是求对于所有 \(k \le K\) 的 \(ans_k\) 的和。
先推推式子。
ans_k &= \sum_{i = k}^{n} \frac{i!}{(i - k)!}\\
&= k! \sum_{i = k}^{n} {i \choose k}\\
&= k! {n + 1 \choose k + 1}
\end{aligned}
\]
那么我们最后就是求对于所有 \(k \le K\) 的 \(k!\) 和 \(\displaystyle {n + 1 \choose k +1}\) 。
前者很好求,对于后者么。。。组合数,\(n\) 好大。。\(Lucas\) ?\(m\) 也好大。。。弃疗
但我们会发现 \(k\) 其实不是很大QAQ
我们需要知道有这样一个东西
\]
为什么呢?思考一下组合意义就很明显啦。
当 \(n = m\) 的时候就有
\]
有了这个就很好做啦~
我们维护一个序列 \(A_i\) 为 \(\displaystyle [{i \choose 0}, {i \choose 1}, \dots, {i \choose K + 1}]\) 。最后我们要求的就是 \(A_{N + 1}\) 。
那么有前面那个式子,我们就可以倍增求出 \(A_n\) 啦。
所以复杂度是 \(O(k^2 \log n)\) 的。(默认不适用慢速乘,用 __int128 )
前面那个是卷积的形式,也可以用 \(FFT\) 优化到 \(O(k \log k \log n)\) ,但由于模数很鬼畜,似乎没有那么优秀。
代码
#include <bits/stdc++.h>
#define For(i, l, r) for (register int i = (l), i##end = (int)(r); i <= i##end; ++i)
#define Fordown(i, r, l) for (register int i = (r), i##end = (int)(l); i >= i##end; --i)
#define Rep(i, r) for (register int i = (0), i##end = (int)(r); i < i##end; ++i)
#define Set(a, v) memset(a, v, sizeof(a))
#define Cpy(a, b) memcpy(a, b, sizeof(a))
#define debug(x) cout << #x << ": " << (x) << endl
using namespace std;
using ll = __int128;
template<typename T> inline bool chkmin(T &a, T b) { return b < a ? a = b, 1 : 0; }
template<typename T> inline bool chkmax(T &a, T b) { return b > a ? a = b, 1 : 0; }
template<typename T>
inline T read() {
T x(0), sgn(1); char ch(getchar());
for (; !isdigit(ch); ch = getchar()) if (ch == '-') sgn = -1;
for (; isdigit(ch); ch = getchar()) x = (x * 10) + (ch ^ 48);
return x * sgn;
}
void File() {
#ifdef zjp_shadow
freopen ("sliding-product-sum.in", "r", stdin);
freopen ("sliding-product-sum.out", "w", stdout);
#endif
}
const int N = 610;
ll n, Mod; int k;
struct Array {
ll a[N];
Array() { Set(a, 0); }
inline Array friend operator * (const Array &lhs, const Array &rhs) {
Array res;
For (i, 0, k) For (j, 0, k - i)
res.a[i + j] = (res.a[i + j] + lhs.a[i] * rhs.a[j]) % Mod;
return res;
}
};
ll fac[N];
Array fpm(Array x, ll power) {
Array res = x; -- power;
for (; power; power >>= 1, x = x * x)
if (power & 1) res = res * x;
return res;
}
int main() {
File();
n = read<ll>() + 1;
k = read<int>() + 1;
Mod = read<ll>();
Array base; base.a[0] = base.a[1] = 1;
Array prod = fpm(base, n);
fac[0] = 1;
For (i, 1, k) fac[i] = fac[i - 1] * i % Mod;
ll ans = 0;
For (i, 2, k)
ans = (ans + fac[i - 1] * prod.a[i]) % Mod;
printf ("%lld\n", (long long)(ans));
return 0;
}
CS Academy Sliding Product Sum(组合数)的更多相关文章
- [codeforces631E]Product Sum
E. Product Sum time limit per test: 1 second memory limit per test: 256 megabytes input:standard inp ...
- Codeforces Round #344 (Div. 2) E. Product Sum 维护凸壳
E. Product Sum 题目连接: http://www.codeforces.com/contest/631/problem/E Description Blake is the boss o ...
- CS Academy Distinct Neighbours(经典dp)
CS Academy Distinct Neighbours(经典dp) 题意: 求相邻无相同数字的合法的排列数 题解: 题解 先将相同的数字分为一类,假设共有n组 定义\(dp[i][j]\)表示前 ...
- Codeforces Round #344 (Div. 2) E. Product Sum 二分斜率优化DP
E. Product Sum Blake is the boss of Kris, however, this doesn't spoil their friendship. They often ...
- CS Academy Gcd on a Circle(dp + 线段树)
题意 给你一个长为 \(n\) 的环,你可以把它断成任意 \(k\) 段 \((1 < k \le n)\) ,使得每一段的 \(\gcd\) 都 \(>1\) . 问总共有多少种方案,对 ...
- Codeforces 631E Product Sum 斜率优化
我们先把问题分成两部分, 一部分是把元素往前移, 另一部分是把元素往后移.对于一个 i 后的一个位置, 我们考虑前面哪个移到这里来最优. 我们设最优值为val, val = max(a[ j ] ...
- CS academy Binary Flips(dp)
开学啦,没啥时间写博客..过几天就能又停课啦qwq 做点中等 \(dp\) 题来找找 noip 的感觉 233 题意 原题戳这里. 给你一个 \(n \times m\) 的矩阵 \(A\) ,一开始 ...
- CS Academy Round #65 Count Arrays (DP)
题目链接 Count Arrays 题意 给定$n$和$m$个区间.若一个长度为$n$的$01$序列满足对于每一个给定的区间中至少有一个位置是$0$, 那么这个$01$序列满足条件.求有多少满足条 ...
- CS Academy #32 G
题意: 分析: 考虑如何求方案数 dp[i][j]表示i个数字的和为j的方案数,这是个经典问题,转移有两种,一个是填一个数字1,一个是整体加1 然后这个问题并不是求方案数,而是求对应的权值和 我们很容 ...
随机推荐
- 第十二届湖南省赛 (B - 有向无环图 )(拓扑排序+思维)好题
Bobo 有一个 n 个点,m 条边的有向无环图(即对于任意点 v,不存在从点 v 开始.点 v 结束的路径). 为了方便,点用 1,2,…,n 编号. 设 count(x,y) 表示点 x 到点 y ...
- MySQL复制表的方式以及原理和流程
复制表的俩种方式: 第一.只复制表结构到新表 create table 新表 select * from 旧表 where 1=2 或者 create table 新表 like 旧表 第二.复制表结 ...
- 项目集成自动分词系统ansj,实现自定义词库
一,分词系统地址:https://github.com/NLPchina/ansj_seg 二,为什么选择ansj? 1.项目需求: 我们平台要做手机售后的舆情分析,即对购买手机的用户的评论进行分析. ...
- IDEA通过Git同步代码到Coding
准备工作: (1)在本地创建好项目 (2)在coding创建好项目,并设置公开 1.创建Git仓库 2.选择对应的本地项目文件夹 以上两步相当于在项目文件夹中git bash here 并 ...
- centos ping www.baidu.com ping: unknown host www.baidu.com
[root@zabbix ~]# cat /etc/resolv.conf ; generated by /sbin/dhclient-script nameserver 219.141.136.10
- day 7-15 表与表之间的关系
一. 前言 表与 表之间有3种对应关系,分别是: 多对一:一张表中的一个字段中的多个值对应另外一张表中的一个字段值.(多个学生,可以学习同一门课程) 多对多;一张表中的一个字段值对应另外一张表中的多个 ...
- HTML5经典案例学习-----新元素添加文档结构
直接上代码了,大家如果发现问题了,记得提醒我哦,谢谢啦,嘻嘻 <!DOCTYPE html> <!-- 不区分大小写 --> <html lang="en&qu ...
- python之路--MySQL多表查询
一 介绍 我们在写项目的时候一般都会建一个数据库,数据库里面会存很多的表,不可能把所有的数据都放在一张表里,因为分表来存数据节省空间,数据的组织结构更清晰,解耦和程度更高,但是这些表本质上还不是一个整 ...
- linux audit审计(6)--audit永久生效的规则配置
定义reboot系统后,仍然生效的审计规则,有两种办法: 1.直接写入/etc/audit/audit.rules文件中,在service文件中需要加入ExecStartPost=-/sbin/aud ...
- Scrapy网络爬虫框架的开发使用
1.安装 2.使用scrapy startproject project_name 命令创建scrapy项目 如图: 3.根据提示使用scrapy genspider spider_name dom ...