不理解Baby Step Giant Step算法,请戳:

http://www.cnblogs.com/chenxiwenruo/p/3554885.html

#include <iostream>
#include <stdio.h>
#include <math.h>
#include <string.h>
#define SIZE 99991
/*
POJ 3243
AC
求解同余方程:
A^x=B(mod C)
*/
using namespace std;
struct HashTable{
int key[SIZE]; //对应A^i
int val[SIZE]; //对应i
void init(){
memset(key,-,sizeof(key));
memset(val,-,sizeof(val));
}
int hfind(int k){
int kk=k%SIZE;
while(key[kk]!=k && key[kk]!=-){
kk=(kk+)%SIZE; //原先写成了kk=(kk+1)&SIZE;导致一直TLE。。。
}
return val[kk];
}
void hinsert(int v,int k){
int kk=k%SIZE;
while(key[kk]!=- && key[kk]!=k){
kk=(kk+)%SIZE;
}
if(key[kk]==-){
key[kk]=k;
val[kk]=v;
}
}
}h; int gcd(int a,int b){
return b==?a:gcd(b,a%b);
}
int exgcd(int a,int b,int &x,int &y){
if(b==){
x=;
y=;
return a;
}
int d=exgcd(b,a%b,x,y);
int tmp=x;
x=y;
y=tmp-a/b*y;
return d;
} //求解ax=b(mod c),
int solvex(int a,int b,int c){
int x,y;
int d;
d=exgcd(a,c,x,y);
//注意这里要强制转换成long long,不然x*b会超出int范围
x=((long long)x*b%c+c)%c;
//x=((long long)x*(b/d)%(c/d)+c/d)%(c/d); //实际应该是这样,但由于传的参数D,B,C中,D、C互质,d=1。
return x;
}
long long quickPow(long long a,int b,int mod){
long long ret=%mod;
a=a%mod;
while(b){
if(b&)
ret=(ret*a)%mod;
a=(a*a)%mod;
b=b>>;
}
return ret;
}
int BabyStep(int A,int B,int C){
B=B%C; //注意这里先要将B对C取模
h.init();
int d=;
long long D=%C,buf=D;
for(int i=;i<=;buf=buf*A%C,++i){
if(buf==B)
return i;
}
int tmp;
while((tmp=gcd(A,C))!=){
if(B%tmp)
return -;
d++;
B=B/tmp;
C=C/tmp;
D=D*A/tmp%C;
}
int m=(int)ceil(sqrt((double)C));
buf=%C;
for(int i=;i<m;buf=buf*A%C,++i){
h.hinsert(i,(int)buf);
}
long long K=quickPow((long long)A,m,C);
for(int i=;i<m;D=D*K%C,++i){
int ans=solvex((int)D,B,C);
int j=h.hfind(ans);
if(j!=-)
return i*m+j+d;
}
return -;
}
int main()
{
int A,B,C;
while(scanf("%d%d%d",&A,&C,&B)!=EOF){
if(A== && B== && C==)
break;
int ans=BabyStep(A,B,C);
if(ans==-)
printf("No Solution\n");
else
printf("%d\n",ans);
}
return ;
}

该题和POJ 2417,HDU 2815 一样,代码稍微改改就能AC。

不过不同的是,HDU 2815  若B>=C,则要判断无解。而不是像POJ这两道题,要先B%C一下。

POJ 3243 Clever Y (求解高次同余方程A^x=B(mod C) Baby Step Giant Step算法)的更多相关文章

  1. POJ 3243 Clever Y 扩展BSGS

    http://poj.org/problem?id=3243 这道题的输入数据输入后需要将a和b都%p https://blog.csdn.net/zzkksunboy/article/details ...

  2. POJ 3243 Clever Y | BSGS算法完全版

    题目: 给你A,B,K 求最小的x满足Ax=B (mod K) 题解: 如果A,C互质请参考上一篇博客 将 Ax≡B(mod C) 看作是Ax+Cy=B方便叙述与处理. 我们将方程一直除去A,C的最大 ...

  3. poj 3243 Clever Y && 1467: Pku3243 clever Y【扩展BSGS】

    扩展BSGS的板子 对于gcd(a,p)>1的情况 即扩展BSGS 把式子变成等式的形式: \( a^x+yp=b \) 设 \( g=gcd(a,p) \) 那么两边同时除以g就会变成: \( ...

  4. POJ 3243 Clever Y(离散对数-拓展小步大步算法)

    Description Little Y finds there is a very interesting formula in mathematics: XY mod Z = K Given X, ...

  5. poj 3243 Clever Y 高次方程

    1 Accepted 8508K 579MS C++ 2237B/** hash的强大,,还是高次方程,不过要求n不一定是素数 **/ #include <iostream> #inclu ...

  6. [POJ 3243]Clever Y

    Description Little Y finds there is a very interesting formula in mathematics: XY mod Z = K Given X, ...

  7. POJ 3243 Clever Y Extended-Baby-Step-Giant-Step

    题目大意:给定A,B,C,求最小的非负整数x,使A^x==B(%C) 传说中的EXBSGS算法0.0 卡了一天没看懂 最后硬扒各大神犇的代码才略微弄懂点0.0 參考资料: http://quarter ...

  8. 解高次同余方程 (A^x=B(mod C),0<=x<C)Baby Step Giant Step算法

    先给出我所参考的两个链接: http://hi.baidu.com/aekdycoin/item/236937318413c680c2cf29d4 (AC神,数论帝  扩展Baby Step Gian ...

  9. 『高次同余方程 Baby Step Giant Step算法』

    高次同余方程 一般来说,高次同余方程分\(a^x \equiv b(mod\ p)\)和\(x^a \equiv b(mod\ p)\)两种,其中后者的难度较大,本片博客仅将介绍第一类方程的解决方法. ...

随机推荐

  1. spring 中的两个DaoSupport类的使用对比

    可以利用NamedParameterJdbcDaoSupport 已经封装的NamedParameterJdbcTemplate方便的进行sql中参数的初始化工作. 相对于JdbcDaoSupport ...

  2. 海蜘蛛ISPV6.1.5,目前破解版本中最稳定的!

    海蜘蛛ISPV6.1.5,目前破解版本中最稳定的! 破解步骤如下: 一.安装完毕进控制台 二.使用muddyboot登陆 密码(123456) 三.输入root回车 四.输入regtools回车 五. ...

  3. jquery页面刷新reload

    今天知道了jquery页面刷新的一个方法,很简单的一句: window.location.reload()刷新当前页面,不得不说我jquery学的很糟糕,明明都学过,但是等用到的时候就想不起来了.不过 ...

  4. Modelsim的demo入门教程

    写在前面的话学过MCU设计的朋友都知道,系统调试是多么的重要.而对于FPGA设计来说,仿真确实最重要的.一个完整的项目,必须有完整的仿真平台.有朋友说,按键仿真模型没法搞. 我只能说,你并不了解硬件及 ...

  5. 20.时钟抖动(jitter)和时钟偏移(skew)的概念?

    jitter:由于晶振本身稳定性,电源以及温度变化等原因造成了时钟频率的变化,就是jitter,指的是时钟周期的变化.指两个时钟周期之间存在的差值,这个误差是在时钟发生器内部产生的,和晶振或者PLL内 ...

  6. Java实现Socket之WhoisClient

    Java实现Socket之WhoisClient 代码内容 从常用的whois服务器的43号端口得到对应域名的所有注册信息并显示出来 代码实现 /* WhoisClient.java */ impor ...

  7. 内核中的 likely() 与 unlikely()

    内核中的 likely() 与 unlikely() 在 2.6 内核中,随处可以见到 likely() 和 unlikely() 的身影,那么为什么要用它们?它们之间有什么区别? 首先要明确: if ...

  8. The underlying JVM is how to realize the synchronized

    http://www.programering.com/a/MjN0IjMwATg.html

  9. Querying mergeinfo requires version 3 of the FSFS filesystem schema

    环境: jdk 1.7; svn  3.0.4;  TortoiseSVN 1.7.13 Subversion 1.7.10; IntelliJ IDEA 13.1.1;win7 64位系统 之前那个 ...

  10. CSS3 filter10种特效整理

    -webkit-filter是css3的一个属性,Webkit率先支持了这几个功能,感觉效果很不错.一共有10种最基本的特效,下来这个DEMO很好的展示了这些效果: <!DOCTYPE html ...