Description

你被要求设计一个计算器完成以下三项任务:

\(1.\)给定\(y,z,p\),计算\(y^{z}\;mod\;P\)的值;

\(2.\)给定\(y,z,p\),计算满足\(xy \equiv z\;mod\;P\)的最小非负整数;

\(3.\)给定\(y,z,p\),计算满足\(y^{x} \equiv z\;mod\;P\)的最小非负整数。

Input

输入包含多组数据。

第一行包含两个正整数\(T,K\)分别表示数据组数和询问类型(对于一个测试点内的所有数据,询问类型相同)。

以下行每行包含三个正整数\(y,z,p\),描述一个询问。

Output

对于每个询问,输出一行答案。对于询问类型\(2\)和\(3\),如果不存在满足条件的,则输出“Orz, I cannot find x!”,注意逗号与“I”之间有一个空格。

Sample Input

3 1

2 1 3

2 2 3

2 3 3

Sample Output

2

1

2

Hint

对于\(100\%\)的数据,\(1 \le y,z,P \le 10^{9}\),\(P\)为质数,\(1 \le T \le 10\)。

数论裸题合集:快速幂,扩展欧几里得,bsgs。

#include<cmath>
#include<cstdio>
#include<cstdlib>
#include<map>
using namespace std; typedef long long ll;
int kind; ll ans; inline ll qsm(ll a,ll b,ll c)
{
ll ret = 1;
for (;b;b >>= 1,(a *= a) %= c)
if (b & 1) (ret *= a) %= c;
return ret;
} inline int gcd(int a,int b)
{
if (!b) return a;
return gcd(b,a%b);
} inline ll bsgs(int a,int b,int c)
{
int i,t = 1;
for (i = 0;i<=50;i++)
{
if (t == b) return i;
t = (ll)t*(ll)a% c;
}
int tmp = 1,k = 1;
t = 1;
while (tmp = gcd(a,c),tmp!=1)
{
if (b % tmp) return -1;
c /= tmp; k++; b /= tmp;
t = (ll)t*(ll)a/tmp%c;
}
int m = (int)sqrt(c+0.5);
map <int,int> hash; hash[1] = 0;
int f = 1;
for (i = 1;i<m;i++)
{
f = (ll)f * (ll)a % c;
hash[f] = i;
}
f = (ll)f*(ll)a%c;
b = qsm(t,c-2,c)*(ll)b%c;
int mod = qsm(f,c-2,c);
for (i = 0;i<m;i++)
{
if (hash.count(b)) return i*m+hash[b]+k-1;
b = (ll)b * (ll)mod % c;
}
return -1;
} int main()
{
freopen("2242.in","r",stdin);
freopen("2242.out","w",stdout);
int T; scanf("%d %d",&T,&kind);
while (T--)
{
int y,z,p;
scanf("%d %d %d",&y,&z,&p);
if (kind == 1) ans = qsm(y,z,p);
else if (kind == 2)
{
y %= p,z %= p;
int d = gcd(y,p);
if (z % d != 0) ans = -1;
else
{
y /= d, p /= d,z /= d;
ans = z*qsm(y,p-2,p)%p;
}
}
else ans = bsgs(y,z,p);
if (ans >= 0) printf("%lld\n",ans);
else printf("Orz, I cannot find x!\n");
}
fclose(stdin); fclose(stdout);
return 0;
}

BZOJ 2242 计算器的更多相关文章

  1. bzoj 2242: [SDOI2011]计算器 BSGS+快速幂+扩展欧几里德

    2242: [SDOI2011]计算器 Time Limit: 10 Sec  Memory Limit: 512 MB[Submit][Status][Discuss] Description 你被 ...

  2. BZOJ 2242: [SDOI2011]计算器( 快速幂 + 扩展欧几里德 + BSGS )

    没什么好说的... --------------------------------------------------------------------- #include<cstdio&g ...

  3. BZOJ 2242: [SDOI2011]计算器 [快速幂 BSGS]

    2242: [SDOI2011]计算器 题意:求\(a^b \mod p,\ ax \equiv b \mod p,\ a^x \equiv b \mod p\),p是质数 这种裸题我竟然WA了好多次 ...

  4. 【BZOJ 2242】[SDOI2011]计算器

    Description 你被要求设计一个计算器完成以下三项任务: 1.给定y,z,p,计算Y^Z Mod P 的值: 2.给定y,z,p,计算满足xy≡ Z ( mod P )的最小非负整数: 3.给 ...

  5. bzoj 2242 [SDOI2011]计算器(数论知识)

    Description 你被要求设计一个计算器完成以下三项任务: 1.给定y,z,p,计算Y^Z Mod P 的值: 2.给定y,z,p,计算满足xy≡ Z ( mod P )的最小非负整数: 3.给 ...

  6. [BZOJ 2242] [SDOI 2011] 计算器

    Description 你被要求设计一个计算器完成以下三项任务: 给定 \(y,z,p\),计算 \(y^z \bmod p\) 的值: 给定 \(y,z,p\),计算满足 \(xy≡ z \pmod ...

  7. BZOJ.2242.[SDOI2011]计算器(扩展欧几里得 BSGS)

    同余方程都不会写了..还一直爆int /* 2.关于同余方程ax ≡b(mod p),可以用Exgcd做,但注意到p为质数,y一定有逆元 首先a%p=0时 仅当b=0时有解:然后有x ≡b*a^-1( ...

  8. BZOJ 2242 [SDOI2011]计算器(快速幂+Exgcd+BSGS)

    [题目链接] http://www.lydsy.com/JudgeOnline/problem.php?id=2242 [题目大意] 给出T和K 对于K=1,计算 Y^Z Mod P 的值 对于K=2 ...

  9. bzoj 2242 [SDOI2011]计算器——BSGS模板

    题目:https://www.lydsy.com/JudgeOnline/problem.php?id=2242 第一道BSGS! 咳咳,我到底改了些什么?…… 感觉和自己的第一版写的差不多……可能是 ...

随机推荐

  1. gdb调试运行时的程序小技巧

    使用gdb调试运行时的程序小技巧 标签: 未分类 gdb pstack | 发表时间:2012-10-15 04:32 | 作者:士豪 分享到: 出处:http://rdc.taobao.com/bl ...

  2. pcap文件格式

      pcap文件格式 pcap文件格式是bpf保存原始数据包的格式,很多软件都在使用,比如tcpdump.wireshark等等,了解pcap格式可以加深对原始数据包的了解,自己也可以手工构造任意的数 ...

  3. springMVC工作原理图

  4. Oracle11g安装完成后给用户解锁

    安装时候你可能忘记给普通用户scott解锁,导致安装成功后普通用户无法登录,那该怎么办呢? 先用system用户登录,登录成功之后就可以给其他用户解锁了. 如图: 同理,如果要锁定某一个用户,只需要把 ...

  5. "ORA-00942: 表或视图不存在 "的原因和解决方法

    "ORA-00942: 表或视图不存在 "的原因和解决方法   采用Oracle数据库,使用Powerdesigner设计,生成Sql文件导入后查询出现“ORA-00942: 表或 ...

  6. Tomcat集群,Nginx集群,Tomcat+Nginx 负载均衡配置,Tomcat+Nginx集群

    Tomcat集群,Nginx集群,Tomcat+Nginx 负载均衡配置,Tomcat+Nginx集群 >>>>>>>>>>>> ...

  7. 核心运营报表无线端数据,pv,uv相关数据,从9月1号开始就没了,为什么?

    问题现象截图 核心运营报表 从获取数据的api的地址可以看出: http://data.51buy.com/json.php?biz=statistic&mod=OrderKeyData&am ...

  8. Bootstrap--全局css样式之表单

    单独的表单控件会被自动赋予一些全局样式.所有设置了 .form-control 类的 <input>.<textarea> 和 <select> 元素都将被默认设置 ...

  9. php错误处理和异常处理

    PHP错误处理有两种:标准的错误处理和异常(OOP语法新出现的错误处理机制)

  10. Jquery 限制文本框输入字数【转】

    <script type="text/javascript" src="js/jquery.min.js" ></script> < ...