bzoj2242
快速幂
扩展欧几里得
baby-step-giant-step
可以自行baidu
程序附部分注释
const key=;
type link=^node;
node=record
re,wh:longint;
next:link;
end; var hash:array[..key] of link;
a:array[..] of longint;
j,g,ans,w,i,n,ch,t,p,z,y:longint;
x,step,k,now:int64; function quick(y,z,p:longint):int64;
var t,i:longint;
begin
quick:=;
t:=;
while z<> do
begin
inc(t);
a[t]:=z mod ;
z:=z div ;
end;
for i:=t downto do
begin
quick:=sqr(quick) mod p;
if a[i]= then quick:=quick*y mod p;
end;
end; function gcd(a,b:longint):longint;
begin
if b= then exit(a)
else exit(gcd(b,a mod b));
end; procedure exgcd(a,b:longint;var x,y:int64); //扩展欧几里得
var xx,yy:int64;
begin
if b= then
begin
x:=;
y:=;
end
else begin
exgcd(b,a mod b,x,y);
xx:=x;
yy:=y;
x:=yy;
y:=xx-(a div b)*yy;
end;
end; procedure add(x,i:longint);
var p:link;
begin
w:=x mod key;
p:=hash[w];
while p<>nil do
begin
if p^.re=x then break;
p:=p^.next;
end;
if p=nil then
begin
new(p);
p^.re:=x;
p^.wh:=i;
p^.next:=hash[w];
hash[w]:=p;
end;
end; function find(x:longint):longint;
var p:link;
begin
find:=-;
w:=x mod key;
p:=hash[w];
while p<>nil do
begin
if p^.re=x then exit(p^.wh);
p:=p^.next;
end;
end; begin
readln(n,ch);
for i:= to n do
begin
readln(y,z,p);
if ch= then
writeln(quick(y,z,p)) //快速幂不多说
else if ch= then
begin
g:=gcd(y,p);
if z mod g<> then //先判断线性模方程是否有解
begin
writeln('Orz, I cannot find x!');
continue;
end;
y:=y div g;
p:=p div g;
z:=z div g;
exgcd(y,p,x,k); //转化为二元一次不定方程
x:=((x*z mod p)+p) mod p; //注意是最小非负数
writeln(x);
end
else begin
z:=z mod p;
t:=trunc(sqrt(p))+; 当t选址为根号p时时间复杂度最优
for j:= to key do
hash[j]:=nil;
now:=;
add(,);
for j:= to t do //求出a^i mod p(<=i<=t) 的值,并映射到hash上,每个模保留最小的i
begin
now:=now*y mod p;
add(now,j);
end;
g:=gcd(now,p);
if g<> then //求出a^t关于mod p的逆元,没有逆元则无解
begin
writeln('Orz, I cannot find x!');
continue;
end
else begin
now:=now div g;
w:=p div g;
end;
exgcd(now,w,x,k);
x:=(x+w) mod w;
ans:=-;
step:=z;
for j:= to t- do
begin
k:=find(step); //大小步寻找 对于a^it ~ a^(i+)t- (<=i<=t-) 寻找可行解
//存在可行解即存在hash中存在模=z*x^i mod p (x表示a^t的逆元)
if k>- then
begin
ans:=k+j*t;
break;
end;
step:=step*x mod p;
end;
if ans=- then writeln('Orz, I cannot find x!')
else writeln(ans);
end;
end;
end.
bzoj2242的更多相关文章
- 【bzoj2242】 SDOI2011—计算器
http://www.lydsy.com/JudgeOnline/problem.php?id=2242 (题目链接) 题意 给出y,z,p.求:1.yz mod p:2.xy=z(mod p):3. ...
- BSGS[bzoj2242][bzoj3122]
数论题. 操作一:直接快速幂就好了. 操作二:我用了exgcd,shy和lyz都喜欢欧拉函数...QAQ最后这块还写错了. 对于ax+by=gcd(a,b)的形式,我们可以把他们变成y'x+p'y=1 ...
- 【BZOJ2242】计算器(BSGS,快速幂)
[BZOJ2242]计算器(BSGS,快速幂) 题面 BZOJ 洛谷 1.给定y.z.p,计算y^z mod p 的值: 2.给定y.z.p,计算满足xy ≡z(mod p)的最小非负整数x: 3.给 ...
- 【BZOJ2242】[SDOI2011]计算器 BSGS
[BZOJ2242][SDOI2011]计算器 Description 你被要求设计一个计算器完成以下三项任务: 1.给定y,z,p,计算Y^Z Mod P 的值: 2.给定y,z,p,计算满足xy≡ ...
- 【bzoj2242】: [SDOI2011]计算器 数论-快速幂-扩展欧几里得-BSGS
[bzoj2242]: [SDOI2011]计算器 1.快速幂 2.扩展欧几里得(费马小定理) 3.BSGS /* http://www.cnblogs.com/karl07/ */ #include ...
- [bzoj2242][Sdoi2011]计算器_exgcd_BSGS
计算器 bzoj-2242 Sdoi-2011 题目大意:裸题,支持快速幂.扩展gcd.拔山盖世 注释:所有数据保证int,10组数据. 想法:裸题,就是注意一下exgcd别敲错... ... 最后, ...
- BZOJ2242 [SDOI2011]计算器
本文版权归ljh2000和博客园共有,欢迎转载,但须保留此声明,并给出原文链接,谢谢合作. 本文作者:ljh2000 作者博客:http://www.cnblogs.com/ljh2000-jump/ ...
- 【BZOJ2242】【SDoi2011】计算器 快速幂+EXGCD+BSGS
Description 你被要求设计一个计算器完成以下三项任务: 1.给定y,z,p,计算Y^Z Mod P 的值: 2.给定y,z,p,计算满足xy≡ Z ( mod P )的最小非负整数: 3.给 ...
- BZOJ-2242 计算器 快速幂+拓展欧几里得+BSGS(数论三合一)
污污污污 2242: [SDOI2011]计算器 Time Limit: 10 Sec Memory Limit: 512 MB Submit: 2312 Solved: 917 [Submit][S ...
- bzoj2242: [SDOI2011]计算器 && BSGS 算法
BSGS算法 给定y.z.p,计算满足yx mod p=z的最小非负整数x.p为质数(没法写数学公式,以下内容用心去感受吧) 设 x = i*m + j. 则 y^(j)≡z∗y^(-i*m)) (m ...
随机推荐
- OC - 12.NSURLRequest与NSURLConnection
##NSURLRequest NSURLRequest封装了一次网络请求所需要的数据,主要封装了以下信息: 请求路径(URL) 请求方法(GET或POST) 请求头 请求体 超时参数 NSURLReq ...
- [转]SQL语句:Group By总结
1. Group By 语句简介: Group By语句从英文的字面意义上理解就是“根据(by)一定的规则进行分组(Group)”.它的作用是通过一定的规则将一个数据集划分成若干个小的区域,然后针对若 ...
- transfrom属性
transfrom可以实现一些形变.常见的有平移.缩放和旋转三种.使用起来很简单: //横纵放大1.3倍 self.imageButton.transform=CGAffineTransformSca ...
- mysql 根据某个字段将多条记录的某个字段拼接成一个字段
未合并情况 SELECT a.id, b.name AS "role" FROM sys_user a INNER JOIN sys_user_role c ON a.id=c.u ...
- jquery api 笔记(2) 事件 事件对象
事件 #1.resize() 缩放窗体:window.resizeTo(width, height); 并不是兼容做法. #2 .scroll() ->获取滚动条的位置: .scro ...
- session 保存在指定的数据表,cookie设置
首先建立数据表,可在ThinkPHP/Extend/Driver/Session/SessionDb.class.php中copy代码 在配置文件中配置: 'SESSION_TYPE' => ' ...
- css中 中文字体(font-family)的标准英文名称
Mac OS的一些: 华文细黑:STHeiti Light [STXihei] 华文黑体:STHeiti 华文楷体:STKaiti 华文宋体:STSong 华文仿宋:STFangsong 儷黑 Pro ...
- MySQL在远程访问时非常慢的解决skip-name-resolve 并且出现 Reading from net
转载:http://www.itokit.com/2012/0515/73932.html 服务器放在局域网内进行测试时,数据库的访问速度还是很快.但当服务器放到外网后,数据库的访问速度就变得非常慢. ...
- 阻止CSS样式被缓存
<link href="/stylesheet.css?<?php echo time(); ?>" rel="stylesheet" typ ...
- html5写的一个时钟
看到的一个html5写的时钟 <!doctype> <html> <head> <script> window.onload=function(){ v ...