Baby-Step_Giant-Step及扩展算法(BSGS)

Baby-Step_Giant-Step(简称BSGS)及其扩展算法(简称Extended BSGS)用来求解 axb(modp) a x ≡ b ( mod p ) 这样的问题
m=p m = ⌈ p ⌉ ,将 x x 分解为im+j,那么 ax=aim+j=aimaj a x = a i ∗ m + j = a i ∗ m ∗ a j
然后我们通过枚举 i i ,来求解同余方程aimajb(modp)
变形得:
aimaj+yp=b a i ∗ m ∗ a j + y ∗ p = b
当前 aj a j y y 未知,将aj看为 x x ,用扩展欧几里得求解即可

其实递推也可以
求解同余方程aimajb(modp)
i=0 i = 0 时显然 aj=b a j = b
接下来每次左边乘上一个 am a m ,移项,得到
ajbinv(am)(modp) a j ≡ b ∗ i n v ( a m ) ( mod p )
所以说 aj=binv(am) a j = b ∗ i n v ( a m )
递推下去即可

我们得到了 aj a j ,怎么得到 j j 呢?
直接将a0,a1...,am1的值映射到一个Hash表里面就好了

代码实现如下:

ll BSGS(ll a,ll b,ll p) {
    if(a%p==0) return -1;
    b%=p;
    ll m=ceil(sqrt(p*1.0));
    hash.clear();
    ll in=1,d=1;
    for(int i=0;i<m;i++) {
        hash.insert(in,i);
        in=(in*a)%p;
    }
    ll a_m_inv=get_inv(in,p);
    for(int i=0;i<m;i++) {
        ll cpt=hash.get(b);
        if(cpt!=-1)
            return i*m+cpt;
        b=(b*a_m_inv)%p;
    }
    return -1;
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值