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 ...
随机推荐
- [moka同学收藏]Vim升华之树形目录插件NERDTree安装图解
无意中看到实验室的朋友使用的vim竟然能在左边显示树形目录,感觉很方便,这样子文件夹有什么文件一目了然.她说是一个插件叫NERDTree,安装执行后的效果如下,不是你想要的效果就别安了.我的系统是Ub ...
- 【夯实PHP系列】PHP正则表达式
一. 概述 1. 正则表达式的测试地址: http://tool.chinaz.com/regex/ 二.具体的常用正则表达式 1. 邮箱正则表达式: 1)\w[-\w.+]*@([A-Za-z0-9 ...
- 【http抓包】记录一次抓手机app的接口
抓手机的接口地址,好用的工具很多,想 windows下的 Fiddler 和mac下的Charles 1. fiddler的设置教程是 http://jingyan.baidu.com/article ...
- IE8兼容模式设置
设置---兼容性视图设置--添加此网站--在IE8中调试(防止调整IE内核后浏览器崩溃,360可通过设置极速模式-兼容模式 点击地址栏绿色图标)
- H5中的touch事件
touch中共有touchstart.touchmove和touchend三个事件: touchstart:触摸开始的时候触发 touchmove:手指在屏幕上滑动的时候触发 touchend:触摸结 ...
- iOS 线程安全之@synchronized的用法
@synchronized(self)的用法: @synchronized 的作用是创建一个互斥锁,保证此时没有其它线程对self对象进行修改.这个是objective-c的一个锁定令牌,防止self ...
- su到普通用户不能起图形 解决办法
环境介绍: 登录系统的时候采用的是root用户,然后su - oracle帐户后,然后执行startx命令启动图形界面之后就报如下的错误,根据提示是PAM起作用了.如下是错误信息:[ora ...
- [转]Design Pattern Interview Questions - Part 4
Bridge Pattern, Composite Pattern, Decorator Pattern, Facade Pattern, COR Pattern, Proxy Pattern, te ...
- ListView实现点击事件以及总结
差点吓死我了,好不容易写的博客没有了,还好有自动保存功能,不然我真的是呜呜... ---恢复内容开始--- 开学一个月了,终于可以看见自己的作品雏形了. 从一个小白到现在半年了,觉得日子过得比较充实, ...
- Oracle索引梳理系列(七)- Oracle唯一索引、普通索引及约束的关系
版权声明:本文发布于http://www.cnblogs.com/yumiko/,版权由Yumiko_sunny所有,欢迎转载.转载时,请在文章明显位置注明原文链接.若在未经作者同意的情况下,将本文内 ...