1. 简介 BSGS 算法也称为大小步算法,主要用来解决 Ax≡Bmod p\begin{array}{c} A^x \equiv B \mod{p} \end{array} Ax≡Bmodp 的问题,其中 ppp 为质数。 2. 算法 令 x=i⋅m−jx = i \cdot m -jx=i⋅m−j,其中 m=⌈p ⌉m = \lceil \sqrt{p} \,\rceilm=⌈p⌉。此时原式等价于 Ai⋅m−j≡Bmod p⇒Ai⋅m≡Aj⋅Bmod p\begin{array}{c} A^{i \cdot m - j} \equiv B \mod{p} \\ \Rightarrow A^{i \cdot m} \equiv A^{j} \cdot B \mod{p} \end{array} Ai⋅m−j≡Bmodp⇒Ai⋅m≡Aj⋅Bmodp 然后枚举 j∈[0,m]j \in [0,m]j∈[0,m],将 Aj⋅BA^{j} \cdot BAj⋅B 存入哈希表;再枚举 i∈[1,m]i \in [1,m]i∈[1,m],从哈希表中寻找第一个满足 Ai⋅m≡Aj⋅Bmod pA^{i \cdot m} \equiv A^{j} \cdot B \mod{p}Ai⋅m≡Aj⋅Bmodp 的 iii,则此时 x=i⋅m−j\begin{array}{c} x = i \cdot m -j \end{array} x=i⋅m−j 即为所求解。该算法复杂度为 O(p )O(\sqrt{p} \,)O(p)。