数学模板-BSGS&&EXBSGS

BSGS

BSGS(baby step giant step)就是求同余方程

axb(modp)

我们设 x=imj ,将其带入式子可以得到
aimjb(modp)
aimbaj(modp)
我们可以计算 bajmodp (i=0 to m)的值(快速幂) 将其放入map中 map[bajmodp]=j
之后再枚举a的im次mod p的值,如果发现再map有对应解
ans=mimap[aimmodp]
可以证明,当 m=p 最快。
为什么 x=imj ,即x的最大值不超过p.
有公式即 ak%p1ak(modp) (当a与p互质),通过小费马证得。
k 可以看成 km(p1) 于是上面的式子变成了
ak(a(p1))mak(modp)
由于小费马, ap11(modp) ,可以得到
ak1mak(modp)
这样就确保了x比p小。

LL BSGS(LL y,LL z,LL p)
{
    map<LL,LL> ma;
    LL m=sqrt(p),tmp=0;
    ma.clear();
    if(y%p==0&&z==0) return 1;
    if(y%p==0&&z!=0) return -1;
    for(int i=0;i<=m;i++)
    {
        if(!i) {tmp=z%p;ma[tmp]=i;continue;}
        tmp=(tmp*y)%p;
        ma[tmp]=i;
    }
    tmp=1;LL t=power(y,m,p);
    for(int i=1;i*i<=p;i++)
    {
        tmp=(tmp*t)%p;
        if(ma[tmp])
        {
            LL ans=i*m-ma[tmp];
            return ans;
        }
    }
    return -1;
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值