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 ...
随机推荐
- Thinking in Java——笔记(19)
Enumerated Types Basic enum features When you create an enum, an associated class is produced for yo ...
- 03-树1 树的同构 (C语言链表实现)
#include <stdio.h> #include <stdlib.h> #include <string.h> #include <stdbool.h& ...
- jQuery Ion.Calendar 日期/日历
在线实例 实例演示 默认 实例演示 每周第一天 实例演示 输入框插件 实例演示 HTML data 属性 实例演示 回调函数1 实例演示 回调函数2 使用方法 <div id="cal ...
- 使用 jQuery & CSS3 制作美丽的照片画廊
在本教程中,我们将创建一个很好看的照片画廊效果.我们的想法是,以显示专辑作为一个滑块,而当这张专辑被选中,我们将使用一个美丽的照片堆栈展示专辑的图像.在照片堆栈视图,我们可以通过将最上面的图像移动到所 ...
- iOS下Audio自动播放(Autoplay)音乐
前几天做了一个H5活动页面,产品要求初始化播放音乐,因晓得H5 Audio标签支持Autoplay就没在意. 完了在手机上测试,发现手机上打开页面死活就是不会自动播放,点击播放按钮才可以播放,很是纠结 ...
- RegExp类型exec()方法的返回值说明
之前看别人写的插件经常会用到RegExp对象来验证输入,并且获取一些那时我并不晓得是什么东西的数组,来取值进行自定义的逻辑处理.今天学习了一下RegExp类型.终于有了一个初步的了解,至少不会看一会就 ...
- Docker 从零开始制作基础镜像[centos]
http://www.oschina.net/news/62897/docker-hub-contains-high-risk-vulnerabilities 这里有个统计,docker官方和个人发布 ...
- 用Kotlin开发Android应用(IV):定制视图和Android扩展
原文标题:Kotlin for Android (IV): Custom Views and Android Extensions 原文链接:http://antonioleiva.com/kotli ...
- HotApp小程序统计云后台 免费的Https云后台服务器,方便学习小程序
小程序学习有些地方需要后台,比如需要存储数据到服务器,比如微信登录. hotapp有免费的小程序云后台 包含基本的 新增,查询,修改,删除 操作,方便于学习,而且不需要微信appid 也可使用. 小程 ...
- React Native环境配置和简单使用
# 前言 学习本系列内容需要具备一定 HTML 开发基础,没有基础的朋友可以先转至 HTML快速入门(一) 学习 本人接触 React Native 时间并不是特别长,所以对其中的内容和性质了解可能会 ...