题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=5446

C(n, m) % (p1*p2*p3*...*pk)的值

其实这个就是中国剩余定理最后算出结果后的最后一步求余

那C(n, m)相当于以前我们需要用中国剩余定理求的值

然而C(n, m)太大,我们只好先算出

C(n, m) % p1 = r1

C(n, m) % p2 = r2

C(n, m) % p3 = r3

.

.

.

C(n, m) % pk = rk

用Lucas,这些r1,r2,r3...rk可以算出来

然后用中国剩余定理求满足num%p[i]=r[i]的最小num即可,num既是所求答案;

注意在运算过程中会出现数相乘爆long long,所以要手动写乘法求余;

#include <iostream>
#include <stdio.h>
#include <string.h>
#include <string>
#include <vector>
#include <algorithm>
#include <map>
#include <queue>
#include <stack>
#include <math.h> using namespace std; #define met(a, b) memset(a, b, sizeof(a))
#define N 153
#define INF 0x3f3f3f3f typedef long long LL; ///快速幂计算a*b%p,因为a*b直接相乘可能会爆LL;
LL Mul(LL a, LL b, LL p)
{
a = (a+p)%p;
b = (b+p)%p;
LL ans = ;
while(b)
{
if(b%)
ans = (ans+a)%p;
a=(a+a)%p;
b/=;
}
return ans;
} ///用快速幂求a^b%p;
LL quick_mod(LL a, LL b, LL p)
{
LL ans = ;
a %= p;
while(b)
{
if(b&)
{
ans = ans*a%p;
b--;
}
b = b/;
a = a*a%p;
}
return ans;
}
///求C(n, m)%p;
LL C(LL n, LL m, LL p)
{
if(m > n)return ;
LL ans = ;
for(int i=; i<=m; i++)
{
LL a = (n+i-m)%p;
LL b = i%p;
ans = ans*(a*quick_mod(b, p-, p)%p)%p;
}
return ans;
}
///卢卡斯用于求C(n, m)%p;
LL Lucas(LL n, LL m, LL p)
{
if(m == )return ;
return C(n%p, m%p, p) * Lucas(n/p, m/p, p)%p;
}
///扩展欧几里德 求ax+by = gcd(a, b)中的x和y
void ex_gcd(LL a, LL b, LL &x, LL &y)
{
if(b == )
{
x = ;
y = ;
return;
}
ex_gcd(b, a%b, x, y);
int t = x;
x = y;
y = t - a/b*y;
if( a*b < )///当ab异号时;
{
x = -x;
y = -y;
}
}
///已知 num%p[i]=r[i];求满足n个式子的最小num,其中p[i]是素数;
LL China(int n, LL p[], LL r[])
{
LL m = , num = ;
for(int i=; i<=n; i++)
m *= p[i];
for(int i=; i<=n; i++)
{
LL x, y, a = m/p[i], b = -p[i];
ex_gcd(a, b, x, y);
LL t = Mul(a, x, m);///Mul就是乘法,防止爆longlong;
num = (num + Mul(t, r[i], m) + m) % m;
}
return (num+m)%m;
} int main()
{
LL n, m;
int k, T;
scanf("%d", &T);
while(T--)
{
LL p[], r[];
scanf("%I64d %I64d %d", &n, &m, &k);
for(int i=; i<=k; i++)
{
scanf("%I64d", &p[i]);
r[i] = Lucas(n, m, p[i]);
}
printf("%I64d\n", China(k, p, r));
}
return ;
}

Unknown Treasure---hdu5446(卢卡斯+中国剩余定理)的更多相关文章

  1. ACM-ICPC 2015 Changchun Preliminary Contest J. Unknown Treasure (卢卡斯定理+中国剩余定理)

    题目链接:https://nanti.jisuanke.com/t/A1842 题目大意:给定整数n,m,k,其中1≤m≤n≤1018,k≤10, 然后给出k个素数,保证M=p[1]*p[2]……*p ...

  2. Unknown Treasure (卢卡斯 + 孙子定理, 模板题)

    Unknown Treasure 参考链接 : https://www.cnblogs.com/linyujun/p/5199684.html 卢卡斯定理 : C(n, m) % p  =  C(n ...

  3. Unknown Treasure(hdu5446)

    Unknown Treasure Time Limit: 1500/1000 MS (Java/Others)    Memory Limit: 131072/131072 K (Java/Other ...

  4. Hdu 5446 Unknown Treasure (2015 ACM/ICPC Asia Regional Changchun Online Lucas定理 + 中国剩余定理)

    题目链接: Hdu 5446 Unknown Treasure 题目描述: 就是有n个苹果,要选出来m个,问有多少种选法?还有k个素数,p1,p2,p3,...pk,结果对lcm(p1,p2,p3.. ...

  5. HDU 5446 Unknown Treasure Lucas+中国剩余定理+按位乘

    HDU 5446 Unknown Treasure 题意:求C(n, m) %(p[1] * p[2] ··· p[k])     0< n,m < 1018 思路:这题基本上算是模版题了 ...

  6. hdu 5446 Unknown Treasure 中国剩余定理+lucas

    题目链接 求C(n, m)%p的值, n, m<=1e18, p = p1*p2*...pk. pi是质数. 先求出C(n, m)%pi的值, 然后这就是一个同余的式子. 用中国剩余定理求解. ...

  7. Lucas+中国剩余定理 HDOJ 5446 Unknown Treasure

    题目传送门 题意:很裸,就是求C (n, m) % (p1 * p2 * p3 * .... * pk) 分析:首先n,m<= 1e18, 要用到Lucas定理求大组合数取模,当然p[]的乘积& ...

  8. HDU 5446 Unknown Treasure(lucas + 中国剩余定理 + 模拟乘法)

    题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=5446 题目大意:求C(n, m) % M, 其中M为不同素数的乘积,即M=p1*p2*...*pk, ...

  9. [SDOI2010] 古代猪文 (快速幂+中国剩余定理+欧拉定理+卢卡斯定理) 解题报告

    题目链接:https://www.luogu.org/problemnew/show/P2480 题目背景 “在那山的那边海的那边有一群小肥猪.他们活泼又聪明,他们调皮又灵敏.他们自由自在生活在那绿色 ...

随机推荐

  1. php eval函数一句话木马代码

    eval可以用来执行任何其他php代码,所以对于代码里发现了eval函数一定要小心,可能是木马 就这一句话害死人,这样任何人都可以post任何文件上来,所以要做好防范 <?php @eval($ ...

  2. git 分支的创建、合并、删除

          基本概念与命令 分支(branch):每次提交,Git都把提交的内容串成一条时间线,这条时间线就是一个分支 .   git 分支的创建 git branch branchName git ...

  3. Docker 集群管理

    docker systemd unit file [Unit] Description=Docker Application Container Engine Documentation=http:/ ...

  4. mysql压力测试工具Mysqlslap

    mysql 性能测试工具:The MySQL Benchmark Suite(不支持多CPU而且不是压力工具) 压力测试工具: MySQL super-smack:需要找能连接外网的机器,能连接外网的 ...

  5. 怎么用MathType编辑带圈字母

    在用word公式编辑器MathType编辑公式时,里面涉及到很多的数学物理符号等等,这些符号或者是公式其实都可以利用MathType中的模板进行组合.在这些数学公式中,有时会有一些比较特殊的符号,它们 ...

  6. 【Matlab】运动目标检测之“帧差法”

    videoObj = VideoReader('4.avi');%读视频文件 nframes = get(videoObj, 'NumberOfFrames');%获取视频文件帧个数 : nframe ...

  7. shell脚本中,将所有的参数值否赋给一个变量或者说将所有的参数合成一个字符串,获取所有参数

    需求描述: 在写脚本的过程中,遇到这样的一个需求,将脚本执行过程中,传递给 脚本的所有的参数,都赋值给一个变量然后在对这个变量进行处理. 测试过程: 通过以下的脚本将所有传递给脚本的变量都赋值一个变量 ...

  8. PHP-007(转)

    今天安装ecshop的时候最上面出现了一个错误提示:Strict Standards: Only variables should be passed by reference in F:\www.x ...

  9. 07python之字符串的常用方法

    字符串作为python中常用的数据类型,掌握字符串的常用方法十分必要. 常用知识点: 1.字符串的3种格式化方法 2.字符串的strip()方法 3.字符串的join()方法 4.字符串可以切片 1. ...

  10. 写了一个简单的CGI Server

    之前看过一些开源程序的源码,也略微知道些Apache的CGI处理程序架构,于是用了一周时间,用C写了一个简单的CGI Server,代码算上头文件,一共1200行左右,难度中等偏上,小伙伴可以仔细看看 ...