Luogu 4345 [SHOI2015]超能粒子炮·改
BZOJ4591
并不会写的组合数学。
我们设$f(n, k) = \sum_{i= 0}^{k}\binom{n}{i}$,那么每一个询问要求的就是$f(n, k)$。
发现$f(i, j)$其实可以递推:
$f(i, 0) = 1$
$f(i, j) = f(i, j - 1) + \binom{i}{j}$
看上去没什么用处,但是我们还有$Lucas$定理。
$f(n, k) = \sum_{i = 0}^{k}\binom{n}{i} \ (Mod\ P) \ =\sum_{i = 0}^{k}\binom{\left \lfloor \frac{n}{P} \right \rfloor}{\left \lfloor \frac{i}{P} \right \rfloor} * \binom{n\%p}{i\%p}$
看到了$\left \lfloor \frac{i}{P} \right \rfloor$这个东西,其实我们知道这个东西一共只有$\sqrt{P}$种取值,所以我们把一样的东西提出来,一共有$\left \lfloor \frac{k}{p} \right \rfloor - 1$个完整的循环节,还有一个不完整的循环节是$\binom{\left \lfloor \frac{n}{P} \right \rfloor}{\left \lfloor \frac{k}{P} \right \rfloor}\sum_{i = 0}^{k \% P}\binom{n\% P}{i}$。
加起来:
$\sum_{i = 0}^{\left \lfloor \frac{k}{p} \right \rfloor - 1}\binom{\left \lfloor \frac{n}{P} \right \rfloor}{i}\sum_{j = 0}^{P - 1}\binom{n \% P}{j} + \binom{\left \lfloor \frac{n}{P} \right \rfloor}{\left \lfloor \frac{k}{P} \right \rfloor}\sum_{i = 0}^{k \% P}\binom{n\% P}{i}$
发现其实是若干个子问题的叠加:
$f(\left \lfloor \frac{n}{P} \right \rfloor , \left \lfloor \frac{k}{P} \right \rfloor - 1)* f(n \% P , P - 1) + f(n \% P , k \% P) * \binom{\left \lfloor \frac{n}{P} \right \rfloor}{\left \lfloor \frac{k}{P} \right \rfloor}$
这样子对于所有的$f$,我们直接递归求解,小于模数的$f$可以直接递推预处理,可以发现递归深度一定不会超过$log$层,还有一个组合数,用$Lucas$定理算一波就好了。
时间复杂度$O(P^2 + Tlogn)$,$log$的底数为$2333$。
Code:
#include <cstdio>
#include <cstring>
using namespace std;
typedef long long ll; const int N = ;
const int P = ; int testCase, c[N][N], f[N][N]; inline int lucas(ll n, ll m) {
if(m == 0LL) return ;
if(n < P && m < P) return c[n][m];
return lucas(n / P, m / P) * c[n % P][m % P] % P;
} inline int solve(ll n, ll k) {
if(k == -1LL) return ;
if(n < P && k < P) return f[n][k];
return (solve(n / P, k / P - ) * solve(n % P, P - ) % P + lucas(n / P, k / P) * solve(n % P, k % P) % P) % P;
} int main() {
c[][] = ;
for(int i = ; i <= P; i++) {
c[i][] = ;
for(int j = ; j <= i; j++)
c[i][j] = (c[i - ][j - ] + c[i - ][j]) % P;
} for(int i = ; i <= P; i++) {
f[i][] = ;
for(int j = ; j <= P; j++)
f[i][j] = (f[i][j - ] + c[i][j]) % P;
} for(scanf("%d", &testCase); testCase--; ) {
ll n, K; scanf("%lld%lld", &n, &K);
printf("%d\n", solve(n, K));
} return ;
}
Luogu 4345 [SHOI2015]超能粒子炮·改的更多相关文章
- Lucas(卢卡斯)定理模板&&例题解析([SHOI2015]超能粒子炮·改)
		Lucas定理 先上结论: 当p为素数: \(\binom{ N }{M} \equiv \binom{ N/p }{M/p}*\binom{ N mod p }{M mod p} (mod p)\) ... 
- Bzoj 4591: [Shoi2015]超能粒子炮·改  数论,Lucas定理,排列组合
		4591: [Shoi2015]超能粒子炮·改 Time Limit: 10 Sec Memory Limit: 256 MBSubmit: 178 Solved: 70[Submit][Stat ... 
- bzoj 4591: [Shoi2015]超能粒子炮·改 [lucas定理]
		4591: [Shoi2015]超能粒子炮·改 题意:多组询问,求 \[ S(n, k) = \sum_{i=0}^n \binom{n}{i} \mod 2333,\ k \le n \le 10^ ... 
- 【BZOJ4591】[SHOI2015]超能粒子炮·改 (卢卡斯定理)
		[BZOJ4591][SHOI2015]超能粒子炮·改 (卢卡斯定理) 题面 BZOJ 洛谷 题解 感天动地!终于不是拓展卢卡斯了!我看到了一个模数,它是质数!!! 看着这个东西就感觉可以递归处理. ... 
- 洛谷 P4345 [SHOI2015]超能粒子炮·改 解题报告
		P4345 [SHOI2015]超能粒子炮·改 题意 求\(\sum_{i=0}^k\binom{n}{i}\),\(T\)组数据 范围 \(T\le 10^5,n,j\le 10^{18}\) 设\ ... 
- bzoj4591 / P4345 [SHOI2015]超能粒子炮·改
		P4345 [SHOI2015]超能粒子炮·改 题意:求$\sum_{i=1}^{k}C(n,i)\%(P=2333)$ 肯定要先拆开,不然怎么做呢(大雾) 把$C(n,i)$用$lucas$分解一下 ... 
- BZOJ_4591_[Shoi2015]超能粒子炮·改_Lucas定理
		BZOJ_4591_[Shoi2015]超能粒子炮·改_Lucas定理 Description 曾经发明了脑洞治疗仪&超能粒子炮的发明家SHTSC又公开了他的新发明:超能粒子炮·改--一种可以 ... 
- 【bzoj4591】[Shoi2015]超能粒子炮·改  Lucas定理
		题目描述 曾经发明了脑洞治疗仪&超能粒子炮的发明家SHTSC又公开了他的新发明:超能粒子炮·改--一种可以发射威力更加强大的粒子流的神秘装置.超能粒子炮·改相比超能粒子炮,在威力上有了本质的提 ... 
- bzoj4591 [Shoi2015]超能粒子炮·改
		Description 曾经发明了脑洞治疗仪&超能粒子炮的发明家SHTSC又公开了他的新发明:超能粒子炮·改--一种可以发射威力更加 强大的粒子流的神秘装置.超能粒子炮·改相比超能粒子炮,在威 ... 
随机推荐
- 20145229吴姗珊 《Java程序设计》第4周学习总结
			20145229吴姗珊 <Java程序设计>第4周学习总结 教材学习内容总结 第六章 继承与多态 6.1继承共同行为 1.继承基本上就是避免多个类间重复定义共同行为 简单的类的定义 使用s ... 
- 编码,charset,乱码,unicode,utf-8与net简单释义
			1.文件分为文本文件和二进制文件﹐不过本质都一样﹐都是些01. 2.计算机存储设备存储的0或1﹐称为计算机的一个二进制位(bit). 3.二进制文件的0和1有专门的应用程序来读﹐所以它们没有什么乱不乱 ... 
- JS中不同类型的值比较问题
			我们比较数据的时候大多是以下两种情况: 3 > 4 ; "m" > "n" ; 但有时候可能会出现比较符号两侧的数据类型不相同的场景,例如 5 &g ... 
- 英语发音规则---发/i:/的字母及字母组合
			英语发音规则---发/i:/的字母及字母组合 一.总结 一句话总结: 1.字母组合ee发/iː/? bee beef see agree week meeting feel sweet free be ... 
- 双系统重装win7和ubuntu修复win7引导方法介绍(来源百度经验)
			很多朋友喜欢为电脑安装win7和ubuntu双系统,当我们重装双系统时,可能会出现win7引导不见的情况,接下来就告诉大家双系统重装win7和ubuntu修复win7引导的方法. 1.win7和ubu ... 
- POJ1363 Rails 验证出栈序列问题
			题目地址: http://poj.org/problem?id=1363 此题只需验证是否为合法的出栈序列. 有两个思路: 1.每个已出栈之后的数且小于此数的数都必须按降序排列.复杂度O(n^2),适 ... 
- java后端书单
			Java开发工程师一般负责后端开发,当然也有专门做Java Web的工程师,但是随着前后端的分离,越来越多的Java工程师需要往大后端方向发展. 今天我们就来介绍一下Java后端开发者的书单. 首先要 ... 
- 11 Python 文件操作
			文件操作基本流程 计算机系统分为:计算机硬件,操作系统,应用程序三部分. 我们用python或其他语言编写的应用程序若想要把数据永久保存下来,必须要保存于硬盘中,这就涉及到应用程序要操作硬件,众所周知 ... 
- kylin_学习_00_资源帖
			一.官方资料 1.官方文档 kylin官方文档(中文) 2.kylin的安装 Hadoop 环境搭建 kylin安装向导 二.参考资料 1.分布式大数据多维分析(OLAP)引擎Apache Kylin ... 
- JavaUtil_09_email_使用 commons-email 发送邮件
			二.参考资料 1.[commons]邮件发送工具——commons-email 
