ICode9

精准搜索请尝试: 精确搜索
首页 > 编程语言> 文章详细

Baby_Step_Gaint_Step(BSGS) 算法

2022-07-20 18:02:37  阅读:165  来源: 互联网

标签:lfloor Gaint 算法 sqrt Step BSGS Baby mod equiv


\(BSGS\) 算法,又称 “北(\(B\))上(\(S\))广(\(G\))深(\(S\))” 算法,“拔山盖世”算法,可以在 \(O(\sqrt{n})\) 的复杂度内求解离散对数问题。


题目描述:

给定质数 \(p\) 和整数 \(a, n\),求最小的非负整数 \(m\) ,满足 \(a^m \equiv n(mod\ \ p)\) 。

算法分析:

最暴力的算法就是每句每一个 \(m \in [1, p]\) ,看一下有没有一个 \(m\) 满足。时间复杂度 \(O(p)\) 。

因此就需要使用 \(\texttt{BSGS}\) 算法来求解 。

\(\texttt{BSGS}\) 算法的流程如下:

  1. 将原式做如下操作:

\[a ^ m \equiv n(mod \ \ p) \]

\[a ^ {k \left \lfloor\sqrt{p}\right\rfloor - b} \equiv n (mod \ \ p) \]

\[a ^ {k \left \lfloor\sqrt{p}\right\rfloor} \equiv n \times a ^ b(mod \ \ p) \]

  1. 易得 \(k \leq \sqrt{q}\),\(b \leq \sqrt{q}\)。

  2. 我们枚举每一个 \(k\) ,将 \(a ^ {k \left \lfloor\sqrt{p}\right\rfloor}\) 的值存到一个 \(hash\) 里面,然后在枚举 \(b\),判断 \(hash\) 中是否存在即可。

时间复杂度 \(O(\sqrt{q})\)。

标签:lfloor,Gaint,算法,sqrt,Step,BSGS,Baby,mod,equiv
来源: https://www.cnblogs.com/LcyRegister/p/16498988.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有