https://www.cnblogs.com/sdzwyq/p/9900650.html

模板:

unordered_map<int, int> mp;
LL q_pow(LL n, LL k, LL p) {
LL ans = 1;
if(k == -1) return 0;
while(k) {
if(k&1) ans = (ans*n) % p;
n = (n*n) % p;
k >>= 1;
}
return ans;
}
int BSGS(int a, int b, int p){
int m = sqrt(p)+1, s = b;
mp.clear();
for(int i = 0; i < m; ++i){
mp[s]=i;
s= (s*1LL*a)%p;
}
int t = q_pow(a, m, p);
s = 1;
for(int i = 1; i <= m; ++i){
s = (s*1LL*t)%p;
if(mp.find(s) != mp.end()) return i*m-mp[s];
}
return -1;
}
int exBSGS(int a, int b, int p) {
int d = __gcd(a, p), k = 1, t = 0;
while(d^1){
if(b%d) return -1;
++t;
b /= d;
p /= d;
k = (k*1LL*(a/d)) % p;
if(b == k) return t;
d = __gcd(a, p);
}
int s = b;
mp.clear();
int m = sqrt(p) + 1;
for(int i = 0;i < m; ++i){
mp[s] = i;
s = (s*1LL*a) % p;
}
s = k;
k = q_pow(a, m, p);
for(int i = 1; i <= m; ++i){
s = (s*1LL*k) % p;
if(mp.find(s) != mp.end()) return i*m-mp[s]+t;
}
return -1;
}

例题:P4195 【模板】exBSGS/Spoj3105 Mod

代码:

#pragma GCC optimize(2)
#pragma GCC optimize(3)
#pragma GCC optimize(4)
#include<bits/stdc++.h>
using namespace std;
#define y1 y11
#define fi first
#define se second
#define pi acos(-1.0)
#define LL long long
//#define mp make_pair
#define pb push_back
#define ls rt<<1, l, m
#define rs rt<<1|1, m+1, r
#define ULL unsigned LL
#define pll pair<LL, LL>
#define pli pair<LL, int>
#define pii pair<int, int>
#define piii pair<pii, int>
#define pdd pair<double, double>
#define mem(a, b) memset(a, b, sizeof(a))
#define debug(x) cerr << #x << " = " << x << "\n";
#define fio ios::sync_with_stdio(false);cin.tie(0);cout.tie(0);
//head unordered_map<int, int> mp;
LL q_pow(LL n, LL k, LL p) {
LL ans = 1;
if(k == -1) return 0;
while(k) {
if(k&1) ans = (ans*n) % p;
n = (n*n) % p;
k >>= 1;
}
return ans;
}
int exBSGS(int a, int b, int p) {
int d = __gcd(a, p), k = 1, t = 0;
while(d^1){
if(b%d) return -1;
++t;
b /= d;
p /= d;
k = (k*1LL*(a/d)) % p;
if(b == k) return t;
d = __gcd(a, p);
}
int s = b;
mp.clear();
int m = sqrt(p) + 1;
for(int i = 0;i < m; ++i){
mp[s] = i;
s = (s*1LL*a) % p;
}
s = k;
k = q_pow(a, m, p);
for(int i = 1; i <= m; ++i){
s = (s*1LL*k) % p;
if(mp.find(s) != mp.end()) return i*m-mp[s]+t;
}
return -1;
}
int a, b, p;
int main() {
while(~scanf("%d %d %d", &a, &p, &b)) {
if(!a && !b && !p) break;
if(b == 1) {
if(p == 1) printf("No Solution\n");
else printf("0\n");
}
else {
int x = exBSGS(a, b, p);
if(~x) printf("%d\n", x);
else printf("No Solution\n");
}
}
return 0;
}

算法笔记--BSGS && exBSGS 模板的更多相关文章

  1. 算法笔记--sg函数详解及其模板

    算法笔记 参考资料:https://wenku.baidu.com/view/25540742a8956bec0975e3a8.html sg函数大神详解:http://blog.csdn.net/l ...

  2. opencv笔记4:模板运算和常见滤波操作

    time:2015年10月04日 星期日 00时00分27秒 # opencv笔记4:模板运算和常见滤波操作 这一篇主要是学习模板运算,了解各种模板运算的运算过程和分类,理论方面主要参考<图像工 ...

  3. BSGS&EXBSGS 大手拉小手,大步小步走

    大步小步走算法处理这样的问题: A^x = B (mod C) 求满足条件的最小的x(可能无解) 其中,A/B/C都可以是很大的数(long long以内) 先分类考虑一下: 当(A,C)==1 即A ...

  4. 算法笔记--数位dp

    算法笔记 这个博客写的不错:http://blog.csdn.net/wust_zzwh/article/details/52100392 数位dp的精髓是不同情况下sta变量的设置. 模板: ]; ...

  5. 算法笔记--lca倍增算法

    算法笔记 模板: vector<int>g[N]; vector<int>edge[N]; ][N]; int deep[N]; int h[N]; void dfs(int ...

  6. [置顶] 小白学习KM算法详细总结--附上模板题hdu2255

    KM算法是基于匈牙利算法求最大或最小权值的完备匹配 关于KM不知道看了多久,每次都不能完全理解,今天花了很久的时间做个总结,归纳以及结合别人的总结给出自己的理解,希望自己以后来看能一目了然,也希望对刚 ...

  7. 学习Java 以及对几大基本排序算法(对算法笔记书的研究)的一些学习总结(Java对算法的实现持续更新中)

    Java排序一,冒泡排序! 刚刚开始学习Java,但是比较有兴趣研究算法.最近看了一本算法笔记,刚开始只是打算随便看看,但是发现这本书非常不错,尤其是对排序算法,以及哈希函数的一些解释,让我非常的感兴 ...

  8. 算法笔记--STL中的各种遍历及查找(待增)

    算法笔记 map: map<string,int> m; map<string,int>::iterator it;//auto it it = m.begin(); whil ...

  9. 算法笔记--priority_queue

    算法笔记 priority_queue<int>que;//默认大顶堆 或者写作:priority_queue<int,vector<int>,less<int&g ...

随机推荐

  1. mybatis传入map任意表增删改查,分页过滤字段

    <!--根据实体参数查询 --> <select id="selectBaseList" resultType="java.util.HashMap&q ...

  2. halcon学习_字符识别1

    实例图片 大体步骤:1.读取图片                   2.图像预处理(阈值分割,提取标签部分,缩小处理区域)                  3.将标签区域的最小外接矩形,从原图中剪 ...

  3. 在Win7环境下搭建Geant4工作平台

    本物理专业小硕,现在材料实验室工作,研究方向大概是核屏蔽材料的软件模拟吧.其实实验室里大多数师兄弟都是搞焊接的,平时能接触到这类直接给源码自己编译的软件的机会基本为零,所以一切都靠自己探索,成功搭建了 ...

  4. 游戏协议模拟测试工具(TcpEngine)使用简介

    功能介绍 在有的网络开发需要走二进制流协议场景,比如网络游戏开发,在开发阶段,前端和后端协商好协议后就分别开发.在开发写代码的时候,有时需要对端发送一条完整的协议过来触发一下自己的代码,进行单步调试或 ...

  5. opencv入门笔记

    一.图片基本操作 1.1 显示图片 #include <opencv2/opencv.hpp> //头文件 using namespace cv; //包含cv命名空间 void main ...

  6. easyui 解决连弹两个dialog时候,第二个dialog居中问题

    $('#showDivSecond').dialog('center'); (该方法自1.3.1版开始可用)

  7. rest_framework之三种分页器使用方法

      from rest_framework.pagination import PageNumberPagination,LimitOffsetPagination,CursorPagination ...

  8. P4568 飞行路线【分层图最短路】

    题目链接:https://www.luogu.org/problem/P4568 题目大意:给定n个点,m条无向边,k次机会经过边时代价为 0 .给出起点和终点,求其最短路径. 解题思路: 两种方法, ...

  9. 简单谈一谈Java内部类的使用原因

    使用内部类的原因 学习总得知其所以然,前面的一篇文章中我有提到过关于java内部类的几种用法以及一些示例,但是不明白内部类具体可以做什么,显然学习起来很渺茫,今天的文章简单说一说使用内部类的几个原因, ...

  10. U1. 广度优先搜索(BFS)和 广度优先搜索(DFS)

    广度优先搜索用栈(stack)来实现,整个过程可以想象成一个倒立的树形: 1.把根节点压入栈中. 2.每次从栈中弹出一个元素,搜索所有在它下一级的元素,把这些元素压入栈中.并把这个元素记为它下一级元素 ...