大步小步法(BSGS) 学习笔记
\(\\\)
BSGS
用于求解关于 \(x\) 的方程:
\]
一般求解的是模意义下的指数,也就是最小非负整数解。
\(\\\)
算法思想
本质是双向搜索,或阈值优化的思想。
首先设"步幅" 为 \(m=\lceil{ \sqrt p}\rceil\) ,然后将方程写作
\]
其中 \(i\) 就是所谓"大步", \(j\) 就是所谓"小步",我们要把他们组合在一起。
直接搜索两个数不如折半搜索一个数,然后再组合。
于是我们可以将分母上的 \(a^j\) 移项,得到
\]
然后就成了比较标准的双向搜索形式。
先把右一半的答案记下来,然后拿左一半搜到的每一个数去查询是否出现过就好了。
\(\\\)
代码实现
对于每一个 \(j\in [0,m-1]\) ,将 \(b\times a^j\ \%\ p\) 的答案放到哈希表里。
然后对于每一个 \(i\in[1,m](\) 此范围依据定义而来,尤其注意!\()\),去哈希表里查是否有 \(a^{im}\ \%\ p\) 的值。
还有两个小优化:
注意到求出为同一个值的 \(j\) ,因为在答案里系数为 \(-1\) ,所以对于求出最小解 \(j\) 肯定是越大越优秀。
因此再哈希表里插入相同的值时,可以直接取 \(max\), 如果是按序插入直接覆盖即可。
这里也延申出了一种做法,直接用 \(map\) 存储结果,将结果映射到 \(j\) ,按序插入直接覆盖,复杂度多个\(log\) 。
运算过程中只需一次快速幂。
一开始每一次都是乘上 \(a\) ,所以一遍循环一遍乘即可,第二步同理,只需题前计算出 \(a^m\) 的值。
这一优化在需要快速乘的时候效果很好。
我们以 [TJOI2007]可爱的质数 一题为例提供一份模板。
#include<map>
#include<cmath>
#include<cstdio>
#include<cctype>
#include<cstring>
#include<cstdlib>
#include<iostream>
#include<algorithm>
#define R register
using namespace std;
typedef long long ll;
map<ll,ll> s;
inline ll qpow(ll x,ll t,ll p){
ll res=1;
while(t){
if(t&1) (res*=x)%=p;
(x*=x)%=p; t>>=1;
}
return res;
}
inline ll BSGS(ll a,ll b,ll p){
b%=p;
ll m=ceil(sqrt(p));
for(R ll i=0;i<m;++i,(b*=a)%=p) s[b]=i;
a=qpow(a,m,p);
for(R ll i=1,tmp=a;i<=m;++i,(tmp*=a)%=p)
if(s.find(tmp)!=s.end()){
if(i*m<s[tmp]) continue;
return i*m-s[tmp];
}
return -1;
}
int main(){
ll a,b,p;
scanf("%lld%lld%lld",&p,&a,&b);
ll x=BSGS(a,b,p);
if(x>=0) printf("%lld\n",x);
else puts("no solution");
return 0;
}
大步小步法(BSGS) 学习笔记的更多相关文章
- 2022-07-10 第五小组 pan小堂 css学习笔记
css学习笔记 什么是 CSS? CSS 指的是层叠样式表* (Cascading Style Sheets) CSS 描述了如何在屏幕.纸张或其他媒体上显示 HTML 元素 CSS 节省了大量工作. ...
- BSGS 扩展大步小步法解决离散对数问题 (BZOJ 3239: Discrete Logging// 2480: Spoj3105 Mod)
我先转为敬? orz% miskcoo 贴板子 BZOJ 3239: Discrete Logging//2480: Spoj3105 Mod(两道题输入不同,我这里只贴了3239的代码) CODE ...
- 微信小程序视频学习笔记
[清华大学]学做小程序 https://www.bilibili.com/video/av21987398 2.2创建项目和文件结构 小程序包含一个描述整体程序的app和多个描述各自页面的page 配 ...
- BSGS学习笔记
用于求\(A^{x} \equiv B \pmod{C}\) 高次方程的最小正整数解x,其中C为素数 引理1:$a^{i\mod\varphi(p) } \equiv a^{i} $ (mod p) ...
- 第1-5章 慕课网微信小程序开发学习笔记
第1章 前言:不同的时代,不同的Web --微信小程序商城构建全栈应用 http://note.youdao.com/noteshare?id=a0e9b058853dbccf886c1a890594 ...
- 小甲鱼Python学习笔记
一 isdigit()True: Unicode数字,byte数字(单字节),全角数字(双字节),罗马数字False: 汉字数字Error: 无 isdecimal()True: Unicode数字, ...
- BSGS 学习笔记
问题:求$a^x\equiv b\ (mod\ p)$的最小正整数解. 这时候就要用到BSGS(拔山盖世)算法.直接进入正题: 设$x=im-n$, 则原式等于$a^{im-n}\equiv b\ ( ...
- 第6章 AOP与全局异常处理6.1-6.4 慕课网微信小程序开发学习笔记
第6章 AOP与全局异常处理 https://coding.imooc.com/learn/list/97.html 目录: 第6章 AOP与全局异常处理6-1 正确理解异常处理流程 13:236-2 ...
- 第7章 数据库访问与ORM 慕课网微信小程序开发学习笔记
第7章 数据库访问与ORM https://coding.imooc.com/learn/list/97.html 目录: 7-1 数据库操作三种方式之原生SQL 19:09 7-2 从一个错误了解E ...
随机推荐
- CALayer与UIView的关系
CALayer属于Core Animation部分的内容,比较重要而不太好理解.以下是园子中看到的一篇文章的摘录: 1. UIView是iOS系统中界面元素的基础,所有的界面元素都是继承自它.它本身完 ...
- 适合初学C语言是练习的代码
作为一个小白,自己学C的时候就想找些代码练练手,就整理了一些. 1.最大公约数和最小公倍数 # include <stdio.h> int main(void) { int i, ...
- Makefile详解 (转--不错就是有点长)
概述 —— 什么是makefile?或许很多Winodws的程序员都不知道这个东西,因为那些Windows的IDE都为你做了这个工作,但我觉得要作一个好的和 professional的程序员,make ...
- JNI/NDK开发指南(2)
1.生成动态库.so,存放于手机的system/lib/中(APP怎样将.so存入该文件夹,奇怪?????),Java层调用JNI的类会运行静态代码System.loadLibrary("* ...
- Why Do Microservices Need an API Gateway?
Why Do Microservices Need an API Gateway? - DZone Integration https://dzone.com/articles/why-do-micr ...
- Mac Mysql [ERR] 2006 - MySQL server has gone away
Mac mysql 安装后,导入sql数据,出现这个错误: 处理方式,是因为sql文件太大,需要修改mysql的配置.如果没有my.cnf就自己建一个. cd /etc sudo vim my.cnf ...
- YTU 2983: 小明的生机!
2983: 小明的生机! 时间限制: 1 Sec 内存限制: 128 MB 提交: 16 解决: 2 题目描述 小明陷入一个充满陷阱的密道之中,现在他要逃脱这里!到达密道的指定位置即可离开这处绝境 ...
- Hibernate是如何延迟加载的
Hibernate是如何延迟加载的 2011-12-24 13:58 242人阅读 评论(0) 收藏 举报 hibernatespringinterceptordao数据库integer Hibern ...
- linux下的git安装及配置
一.yum安装方式 1.安装 $ yum install curl-devel expat-devel gettext-devel openssl-devel zlib-devel $ yum -y ...
- 并不对劲的bzoj4868: [Shoi2017]期末考试
传送门-> 三分裸题. 发现答案只和最后一个科目公布成绩的时间有关. 科目公布成绩的时间越早,老师们的不愉快度越高,这个时间越晚,学生们的不愉快度越高. 它看上去像个单峰的,那么就三分好了. 判 ...