BZOJ4591——[Shoi2015]超能粒子炮·改
1、题意:求  
2、分析:公式恐惧症的同学不要跑啊QAQ 
根据lucas定理—— 
 
        
 这一步大家都能懂吧,这是浅而易见的lucas定理转化过程,将每一项拆分成两项 
 那么下一步,我们将同类项合并 
 我们观察可以发现1..2332 / 2333都是0 
 那么我们将其中2332项提取出来变成 
  
 同理,2333..4665 / 2333都是1,我们同样提出这个公因式 
 因此可以得到 
  
 接下去,我们可以以的到达k/2333-1这里,都是类似的 
 那么我们提取,得到 
  
 我们完成了一部分,那么剩下的还有k/2333的这一部分,我们依旧提取公因式 
  
那么我们令 为  
我们可以得到最终答案的式子
我们观察这个式子,他简直就是这个问题的简化版 
那么这个式子其实是等于 的,十分浅显易懂,那么我们就可以将此题不断的缩小再缩小,注意那个C数组和sum数组都预处理出来,只预处理小于2333的,太大的C用lucas定理解决,完美解决,撒花!
#include <cstdio>
#include <cstdlib>
#include <cstring>
#include <algorithm>
using namespace std;
#define M 2500
#define MOD 2333
#define LL long long
inline int read(){
    char ch = getchar(); int x = 0, f = 1;
    while(ch < '0' || ch > '9'){
        if(ch == '-') f = -1;
        ch = getchar();
    }
    while('0' <= ch && ch <= '9'){
        x = x * 10 + ch - '0';
        ch = getchar();
    }
    return x * f;
}
inline LL llread(){
    char ch = getchar(); LL x = 0, f = 1;
    while(ch < '0' || ch > '9'){
        if(ch == '-') f = -1;
        ch = getchar();
    }
    while('0' <= ch && ch <= '9'){
        x = x * 10 + ch - '0';
        ch = getchar();
    }
    return x * f;
}
int c[M][M], sum[M][M];  
inline void init(){
    c[0][0] = sum[0][0] = 1;
    for(int i = 1; i < MOD; i ++) sum[0][i] = 1;
    for(int i = 1; i < MOD; i ++){
        sum[i][0] = c[i][0] = 1;
        for(int j = 1; j <= i; j ++) c[i][j] = (c[i - 1][j - 1] + c[i - 1][j]) % MOD;
        for(int j = 1; j < MOD; j ++) sum[i][j] = (sum[i][j - 1] + c[i][j]) % MOD;
    }
}
inline int Lucas(LL x, LL y){
    if(x < y || y < 0) return 0;
    if(x < MOD && y < MOD) return c[x][y];
    return Lucas(x / MOD, y / MOD) * c[x % MOD][y % MOD] % MOD;
}  
inline int cal(LL n, LL k){
    if(k < 0) return 0;
    return (cal(n / MOD,k / MOD - 1) * sum[n % MOD][MOD - 1] % MOD + Lucas(n / MOD, k / MOD) * sum[n % MOD][k % MOD] % MOD) % MOD;
}  
int main(){
    init();
    int T = read();
    while(T --){
        LL n = llread(), k = llread();
        printf("%d\n", cal(n, k));
    }
    return 0;
}
BZOJ4591——[Shoi2015]超能粒子炮·改的更多相关文章
- bzoj4591 [Shoi2015]超能粒子炮·改
		
Description 曾经发明了脑洞治疗仪&超能粒子炮的发明家SHTSC又公开了他的新发明:超能粒子炮·改--一种可以发射威力更加 强大的粒子流的神秘装置.超能粒子炮·改相比超能粒子炮,在威 ...
 - [bzoj4591][Shoi2015][超能粒子炮·改] (lucas定理+组合计数)
		
Description 曾经发明了脑洞治疗仪&超能粒子炮的发明家SHTSC又公开了他的新发明:超能粒子炮·改--一种可以发射威力更加 强大的粒子流的神秘装置.超能粒子炮·改相比超能粒子炮,在威 ...
 - [BZOJ4591][SHOI2015]超能粒子炮·改(Lucas定理+数位DP)
		
大组合数取模可以想到Lucas,考虑Lucas的意义,实际上是把数看成P进制计算. 于是问题变成求1~k的所有2333进制数上每一位数的组合数之积. 数位DP,f[i][0/1]表示从高到低第i位,这 ...
 - BZOJ4591 SHOI2015超能粒子炮·改(卢卡斯定理+数位dp)
		
注意到模数很小,容易想到使用卢卡斯定理,即变成一个2333进制数各位组合数的乘积.对于k的限制容易想到数位dp.可以预处理一发2333以内的组合数及组合数前缀和,然后设f[i][0/1]为前i位是否卡 ...
 - bzoj千题计划279:bzoj4591: [Shoi2015]超能粒子炮·改
		
http://www.lydsy.com/JudgeOnline/problem.php?id=4591 最后的式子合并同类项 #include<cstdio> #include<i ...
 - bzoj4591 [Shoi2015]超能粒子炮·改——组合数学(+求阶乘逆元新姿势)
		
题目:https://www.lydsy.com/JudgeOnline/problem.php?id=4591 这题不是很裸啊(所以我就不会了) 得稍微推导一下,看这个博客好了:https://bl ...
 - 【BZOJ4591】[SHOI2015]超能粒子炮·改 (卢卡斯定理)
		
[BZOJ4591][SHOI2015]超能粒子炮·改 (卢卡斯定理) 题面 BZOJ 洛谷 题解 感天动地!终于不是拓展卢卡斯了!我看到了一个模数,它是质数!!! 看着这个东西就感觉可以递归处理. ...
 - bzoj4591 / P4345 [SHOI2015]超能粒子炮·改
		
P4345 [SHOI2015]超能粒子炮·改 题意:求$\sum_{i=1}^{k}C(n,i)\%(P=2333)$ 肯定要先拆开,不然怎么做呢(大雾) 把$C(n,i)$用$lucas$分解一下 ...
 - 【BZOJ-4591】超能粒子炮·改      数论 + 组合数 + Lucas定理
		
4591: [Shoi2015]超能粒子炮·改 Time Limit: 10 Sec Memory Limit: 256 MBSubmit: 95 Solved: 33[Submit][Statu ...
 
随机推荐
- [LeetCode] Trapping Rain Water 收集雨水
			
Given n non-negative integers representing an elevation map where the width of each bar is 1, comput ...
 - QinQ
			
7.3.1 QinQ技术诞生的背景 --<华为交换机学习指南> QinQ最初主要是为扩展VLAN ID空间而产生的,但随着城域以太网的发展以及运营商精细化运作的要求,QinQ的双层标签又有 ...
 - Gone Fishing POJ 1042
			
#include<cstdio> #include<iostream> #include<algorithm> #include<cstring> us ...
 - 【MySQL】函数IFNULL、设置默认时间
			
MySql 函数 IFNUll用法说明 IFNULL(expr1,expr2) 如果 expr1 不是 NULL,IFNULL() 返回 expr1,否则它返回 expr2. IFNULL()返回一个 ...
 - python基础补漏-06-其他常用模块
			
JSON/Pickle: 首先我们要明白 什么事序列化--> 就是进行不同程序之间的数据交换 那JSON 和Pickle是什么鬼... 就是不同的方式而已 import json name = ...
 - 对于多个数据库表对应一个Model问题的思考
			
最近做项目遇到一个场景,就是客户要求为其下属的每一个分支机构建一个表存储相关数据,而这些表的结构都是一样的,只是分属于不同的机构.这个问题抽象一下就是多个数据库表对应一个Model(或者叫实体类).有 ...
 - 进度条投票-W
			
<!DOCTYPE html><html lang="en"><head> <meta charset="UTF-8" ...
 - python读取caffemodel文件
			
caffemodel是二进制的protobuf文件,利用protobuf的python接口可以读取它,解析出需要的内容 不少算法都是用预训练模型在自己数据上微调,即加载"caffemodel ...
 - substr()函数
			
substr 定义于头文件 <string> string substr (size_t pos = 0, size_t len = npos) const;复制子字符串,要求从指定位置开 ...
 - CSS之列表标签
			
1 无序列表 无序列表,用来表示一个列表的语义,并且每个项目和每个项目之间,是不分先后的. ul就是英语unordered list,"无序列表"的意思. li 就是英语list ...