快速幂求逆元

思路

题意:

给出两个整数 a , p a,p a,p,其中 p p p 是质数,求出一个整数 b b b,使得 a ∗ b = 1 ( m o d p ) a~*~b~=~1(mod~p) a ∗ b = 1(mod p) 成立(即求 a a a 模 p p p 的乘法逆元)。

首先我们需要记住费马小定理 :若 p p p 为质数且 a m o d p ! = 0 a~mod~p~!=~0 a mod p != 0,那么式子 a p − 1 = 1 ( m o d p ) a^{p-1}~=~1(mod~p) ap−1 = 1(mod p) 成立。

我们可以把这个式子转化为 p ∗ a p − 2 = 1 ( m o d p ) p~*~a^{p-2}~=~1(mod~p) p ∗ ap−2 = 1(mod p)。

那么易知:

当 a m o d p ! = 0 a~mod~p~!=~0 a mod p != 0 时,需要求的乘法逆元 b b b 的值等于 a p − 2 a^{p-2} ap−2;当 a m o d p = 0 a~mod~p~=~0 a mod p = 0 时,乘法逆元不存在。

C o d e Code Code

cpp 复制代码
#include <bits/stdc++.h>
#define int long long
#define sz(a) ((int)a.size())
#define all(a) a.begin(), a.end()
using namespace std;
using PII = pair<int, int>;
using i128 = __int128;
const int N = 2e5 + 10;

int qpow(int a, int b, int p) {
	int res = 1;
	while (b) {
		if (b & 1) {
			res = res * a % p;
		}
		a = a * a % p;
		b >>= 1;
	}
	return res;
}

signed main() {
	int a, p;
	cin >> a >> p;
	if (p >= 2 && a % p) {
		cout << qpow(a, p - 2, p) << "\n";
	} else {
		cout << "impossible\n";
	}
	return 0;
}
相关推荐
落地加湿器几秒前
Acwing算法课图论与搜索笔记
c++·笔记·算法·图论·dfs·bfs·图搜索算法
cui_ruicheng几秒前
C++ 数据结构进阶:哈希表原理
数据结构·c++·算法·哈希算法
黎阳之光1 分钟前
黎阳之光:AI硬核技术锚定十五五,赋能海空天全域智能感知
大数据·人工智能·算法·安全·数字孪生
xiaoye-duck2 分钟前
C++ 二叉搜索树(BST)深度解析:从概念原理、核心操作到底层实现
数据结构·c++
卷福同学6 分钟前
【养虾日记】如何让Openclaw联网搜索技能
人工智能·算法
努力学习的小廉7 分钟前
我爱学算法之——floodfill算法(上)
学习·算法
tankeven11 分钟前
HJ136 翻之
c++·算法
robch1 小时前
golang container/heap 是一个为任意类型实现堆(优先队列)接口的包
数据结构·算法·golang
96771 小时前
力扣面试经典150 88. 合并两个有序数组 归并排序的merge函数
算法·leetcode·面试
放下华子我只抽RuiKe59 小时前
算法的试金石:模型训练、评估与调优的艺术
人工智能·深度学习·算法·机器学习·自然语言处理·数据挖掘·线性回归