博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
BZOJ2242 计算器
阅读量:6713 次
发布时间:2019-06-25

本文共 2029 字,大约阅读时间需要 6 分钟。

目录

BZOJ2242 计算器

题解

一道比较模板的题目,第一个操作暴力快速幂搞,第二个操作暴力\(Exgcd\)搞,第三个操作暴力\(BSGS\)搞。注意判无解的情况就行了。

code

#include 
using namespace std;typedef long long ll;bool Finish_read;template
inline void read(T &x){Finish_read=0;x=0;int f=1;char ch=getchar();while(!isdigit(ch)){if(ch=='-')f=-1;if(ch==EOF)return;ch=getchar();}while(isdigit(ch))x=x*10+ch-'0',ch=getchar();x*=f;Finish_read=1;}template
inline void print(T x){if(x/10!=0)print(x/10);putchar(x%10+'0');}template
inline void writeln(T x){if(x<0)putchar('-');x=abs(x);print(x);putchar('\n');}template
inline void write(T x){if(x<0)putchar('-');x=abs(x);print(x);}/*================Header Template==============*/#define PAUSE printf("Press Enter key to continue..."); fgetc(stdin);ll y,z,p;std::map
Mp;int T,k;/*==================Define Area================*/ll Powe(ll x,ll y,ll p) { ll res=1; while(y) { if(y&1) res*=x,res%=p; x*=x;x%=p; y>>=1; } return res;}void Exgcd(ll a,ll b,ll &x,ll &y) { if(!b) { x=1,y=0; return ; } Exgcd(b,a%b,x,y); ll t=x;x=y;y=t-a/b*y;}ll Gcd(ll x,ll y) { if(!y) return x; else return Gcd(y,x%y);}void Solve1(ll a,ll b,ll c) { ll ans=Powe(a,b,c); printf("%lld\n",ans); return ;}void Solve2(ll a,ll b,ll c) { c=-c; ll G=Gcd(a,c); if(b%G!=0) { puts("Orz, I cannot find x!"); return ; } a/=G;b/=G;c/=G; ll x,y; Exgcd(a,c,x,y); x=x*b%c; while(x<0) x+=c; printf("%lld\n",x); return ;}void Solve3(ll a,ll b,ll c) { Mp.clear(); if(!(a%c)) { puts("Orz, I cannot find x!"); return ; } ll m=ceil(sqrt(c)); ll t=b; for (int i=0;i<=m;i++) { Mp[t]=i; t=t*a%c; } ll s=Powe(a,m,c);t=s; for (int i=1;i<=m;i++) { ll v=Mp[t]; if (v!=0) { printf("%lld\n",i*m-v); return; } t=t*s%c; } puts("Orz, I cannot find x!");}int main() { read(T);read(k); while(T--) { ll a,b,c; read(a);read(b);read(c); if(k==1) Solve1(a,b,c); else if(k==2) Solve2(a,b,c); else Solve3(a,b,c); } return 0;}/*3 12 1 32 2 32 3 3*//*3 22 1 32 2 32 3 3*/

转载于:https://www.cnblogs.com/Apocrypha/p/9435621.html

你可能感兴趣的文章
LVM配置与管理
查看>>
RAC节点服务ora.rac2.gsd的offline问题解决方法
查看>>
SharedPreferences小细节
查看>>
Configuring Default-network for EIGRP
查看>>
【我们都爱Paul Hegarty】斯坦福IOS8公开课个人笔记32 NSNotification
查看>>
【嵌入式】探究bootloader,分析u-boot源码
查看>>
Oracle数据库通过定义TYPE及Member对象来实现日志信息的分级管理
查看>>
pb之autocommit
查看>>
UDT拥塞控制算法
查看>>
Bsidesiowa 2015 Track2: Secure Process Isolation With Docker By Greg Rice
查看>>
解决开机 svchost.exe 进程占用居高不下的问题
查看>>
如何控制某个方法允许并发访问线程的个数?
查看>>
Android2.2 API 中文文档系列(2) —— EditText
查看>>
openstack iptables
查看>>
Matlab中的ans小结
查看>>
三行代码接入,社交软件打字时底下弹出的表情布局,自定义ViewPager+页面点标+各种功能的android小框架。...
查看>>
nginx学习总结二(nginx的启动停止以及版本平滑升级)
查看>>
linux网卡绑定
查看>>
fastjson报java.lang.ClassNotFoundError
查看>>
Microsoft Dynamics CRM server 2013 系统和SQL server 备份 为升级 CRM 2015版本准备
查看>>