BZOJ1951[SDOI2010]古代猪文
Description
Input
Output
Sample Input
Sample Output
HINT
10%的数据中,1 <= N <= 50;
20%的数据中,1 <= N <= 1000;
40%的数据中,1 <= N <= 100000;
100%的数据中,1 <= G <= 1000000000,1 <= N <= 1000000000。
题解:
P即为∑C(n,k),注意在求P时应对(999911659-1)取模。
因为999911658为合数,则需进行质因数分解,再通过中国剩余定理合并。
对于一个指数pi,其指数为ti,计算在模pi^ti下的组合数的值。
C(n,k)=n!/(k!*(n-k)!)。
在求x!时记录pi因子出现多少次、剩余因子乘积模pi^ti的值。
对于不含pi因子的数,其模pi^ti的结果pi次一循环,可以以此快速运算。
在进行除法时,对于pi因子个数,将其相减去,将剩下的个数乘到结果上;对于其他因子乘积,用exgcd来求逆元。
通过中国剩余定理合并后求和,最后快速幂求出答案。
注意G是999911859倍数的情况,应该直接输出0。
代码:
var
i,j,ii:longint;
k,l,n,m,t,q,y,z,p,x,g,ll,ans:int64;
aa,mm:array[..]of int64;
qz:array[..,..]of int64;
function powi(a,b,c:int64):int64;
var d:int64;
begin
d:=;
while b> do
begin
if b mod = then d:=(a*d)mod c;
b:=b div ; a:=(a*a)mod c;
end;
exit(d);
end;
procedure ex(a,b:int64;var x,y:int64);
var xx:int64;
begin
if b= then begin x:=; y:=; exit; end;
ex(b,a mod b,x,y);
xx:=x; x:=y; y:=xx-(a div b)*y;
end;
function inv(a,p:int64):int64;
var x,y:int64;
begin
ex(a,p,x,y);
exit((x+p)mod p);
end;
procedure jc(l,a,p,p0:int64;var b,c:int64);
begin
if a= then begin b:=; c:=; exit; end;
x:=; y:=; b:=; c:=;
jc(l,a div p0,p,p0,b,c);
b:=b+(a div p0);
c:=(powi(qz[l,p-],a div p,p)*qz[l,a mod p]mod p)*c mod p;
end;
function cc(l,a,b,p,p0:int64):int64;
var b1,b2,b3,c1,c2,c3:int64;
begin
jc(l,a,p,p0,b1,c1);
jc(l,b,p,p0,b2,c2);
jc(l,a-b,p,p0,b3,c3);
exit(((c1*inv(c2,p)mod p)*inv(c3,p)mod p)*powi(p0,b1-b2-b3,p)mod p);
end;
function ss(y,z,p:int64):int64;
var i,m:longint;
q,pp:int64;
begin
pp:=p; i:=; m:=; l:=;
while p> do
begin
if i*i>p then i:=p;
if p mod i= then
begin
q:=;
while p mod i= do
begin p:=p div i; q:=q*i; end;
inc(m); aa[m]:=cc(m,z,y,q,i); mm[m]:=q;
end;
inc(i);
end;
q:=;
for i:= to m do
q:=(q+(aa[i]*inv(pp div mm[i],mm[i])mod pp)*(pp div mm[i])mod pp)mod pp;
exit(q);
end;
begin
readln(n,g);
if g mod = then begin writeln(); halt; end;
p:=; i:=;
while p> do
begin
if i*i>p then i:=p;
if p mod i= then
begin
q:=; inc(ll);
while p mod i= do
begin p:=p div i; q:=q*i; end;
qz[ll,]:=;
for ii:= to q- do
begin
qz[ll,ii]:=qz[ll,ii-];
if ii mod i> then qz[ll,ii]:=(qz[ll,ii]*ii)mod q;
end;end;
inc(i);
end;
for i:= to trunc(sqrt(n))do
if n mod i= then
begin
ans:=(ans+ss(i,n,))mod ;
if n div i<>i then ans:=(ans+ss(n div i,n,))mod ;
end;
ans:=(powi(g,ans,));
writeln(ans);
end.
BZOJ1951[SDOI2010]古代猪文的更多相关文章
- [bzoj1951] [Sdoi2010]古代猪文 费马小定理+Lucas定理+CRT
Description "在那山的那边海的那边有一群小肥猪.他们活泼又聪明,他们调皮又灵敏.他们自由自在生活在那绿色的大草坪,他们善良勇敢相互都关心--" --选自猪王国民歌 很久 ...
- BZOJ1951:[SDOI2010]古代猪文(Lucas,CRT)
Description “在那山的那边海的那边有一群小肥猪.他们活泼又聪明,他们调皮又灵敏.他们自由自在生活在那绿色的大草坪,他们善良勇敢相互都关心……” ——选自猪王国民歌 很久很久以前,在山的那边 ...
- BZOJ1951 [Sdoi2010]古代猪文 【费马小定理 + Lucas定理 + 中国剩余定理 + 逆元递推 + 扩展欧几里得】
题目 "在那山的那边海的那边有一群小肥猪.他们活泼又聪明,他们调皮又灵敏.他们自由自在生活在那绿色的大草坪,他们善良勇敢相互都关心--" --选自猪王国民歌 很久很久以前,在山的那 ...
- BZOJ1951 [Sdoi2010]古代猪文 中国剩余定理 快速幂 数论
原文链接http://www.cnblogs.com/zhouzhendong/p/8109156.html 题目传送门 - BZOJ1951 题意概括 求 GM mod 999911659 M=∑i ...
- bzoj千题计划323:bzoj1951: [Sdoi2010]古代猪文(Lucas+CRT+欧拉定理)
https://www.lydsy.com/JudgeOnline/problem.php?id=1951 先欧拉降幂 然后模数质因数分解 分别计算组合数的结果,中国剩余定理合并 #include&l ...
- bzoj1951 [Sdoi2010]古代猪文 ——数论综合
题目:https://www.lydsy.com/JudgeOnline/problem.php?id=1951 题意就是要求 G^( ∑(k|n) C(n,k) ) % p,用费马小定理处理指数,卢 ...
- 【BZOJ1951】[SDOI2010]古代猪文
[BZOJ1951][SDOI2010]古代猪文 题面 bzoj 洛谷 题解 题目实际上是要求 $ G^{\sum d|n\;C_n^d}\;mod \; 999911659 $ 而这个奇怪的模数实际 ...
- 【BZOJ1951】[Sdoi2010]古代猪文 Lucas定理+CRT
[BZOJ1951][Sdoi2010]古代猪文 Description 求$X=\sum\limits_{d|n}C_n^d$,$Ans=G^X (\mod 999911659)$. Input 有 ...
- 【bzoj1951】: [Sdoi2010]古代猪文 数论-中国剩余定理-Lucas定理
[bzoj1951]: [Sdoi2010]古代猪文 因为999911659是个素数 欧拉定理得 然后指数上中国剩余定理 然后分别lucas定理就好了 注意G==P的时候的特判 /* http://w ...
随机推荐
- 关于依赖注入IOC/DI的感想
之前一直不明白依赖注入有什么好处,甚至觉得它是鸡肋,现在想想,当时真是可笑. 这个想法正如同说接口是没有用处一样. 当整个项目非常庞大,各个方法之间的调用非常复杂,那么,可以想象一下,假设说没有任何的 ...
- springmvc+mybatis+spring 整合源码项目
A集成代码生成器 [正反双向(单表.主表.明细表.树形表,开发利器)+快速构建表单; freemaker模版技术 ,0个代码不用写,生成完整的一个模块,带页面.建表sql脚本,处理类,service等 ...
- [python]沪深龙虎榜数据进一步处理,计算日后5日的涨跌幅
沪深龙虎榜数据进一步处理,计算日后5日的涨跌幅 事前数据: 前面处理得到的csv文件 文件名前加入“[wait]”等待程序处理 python代码从雅虎股票历史数据api获取数据,计算后面5日的涨跌幅 ...
- iOS 线程安全之@synchronized的用法
@synchronized(self)的用法: @synchronized 的作用是创建一个互斥锁,保证此时没有其它线程对self对象进行修改.这个是objective-c的一个锁定令牌,防止self ...
- Xcode8开发iOS10推送通知过程
iOS10发布后,简书优先开发增加了iOS10的新通知.本文分享整个feature的开发过程遇到的问题. 1.工程配置 Xcode8发生了很大的变化,直接打开原来的工程编译运行,这个时候是获取不到Pu ...
- 一起来学习Android自定义控件2-简单的写字板控件
概述 上一篇文章我们对自定义控件进行了一个大体的知识介绍.今天就来学习自定义一个简单的写字板控件. 先来看看效果图 就是简单的根据手指写下的轨迹去画出内容 实现 在上一篇文章里提到了android官方 ...
- Tableview中Dynamic Prototypes动态表的使用
Tableview时IOS中应用非常广泛的控件,当需要动态的添加多条不同的数据时,需要用动态表来实现,下面给出一个小例子,适用于不确定Section的数目,并且每个Section中的行数也不同的情况, ...
- SDK的制作详解
一个简单的SDK制作是很容易的,复杂的sdk其实就和复杂化的应用一样,都是从简单开始的,这里介绍一下sdk的简单制作 步骤: 1.创建sdk,公开文件 2.编译.获取sdk文件 3.导入工程,配置文件 ...
- 基于Ruby的watir-webdriver自动化测试方案与实施(五)
接着基于Ruby的watir-webdriver自动化测试方案与实施(四) http://www.cnblogs.com/Javame/p/4164570.html 继续 ... ... 关于特殊控件 ...
- Meet Sccot Guthrie in Shanghai
9月16日,有幸和其他9位MVP一起在上海和微软全球副总裁Sccot Guthrie.开发工具部门Somasegar.微软中国申元庆见面,聊关于Azure和开发方面的话题.同时,由于本人目前对物联网( ...