经典算法 (A/B) mod C

(A/B) mod C

问题描述

求(A/B)%C,但由于A和B实在太大了,我们只给出A % C,B % C。

(我们保证给定的A必能被B整除,且gcd(B,C) = 1)。

输入描述

输入一行三个整数,分别是A % C,B % C,C。

输出描述

输出(A/B)%C的值。

输入示例1

in 复制代码
22 11 49

输出示例1

out 复制代码
2

样例解释

in 复制代码
(6000 / 60) % 49 = 2
60与49最大公约数为1,
6000%49 = 22,60 % 49 = 11
输入22 11 49
输出2

输入示例2

in 复制代码
1000 53 9973

输出示例2

out 复制代码
7922

输入示例3

in 复制代码
87 1022 9973

输出示例3

out 复制代码
6060

c++代码(拓展欧几里得算法 通用法,也就是C可以为任意实数)

cpp 复制代码
#include<bits/stdc++.h>

using namespace std;

typedef long long ll;

ll A, B, C;

ll extend_gcd(ll a, ll b, ll &x, ll &y) {//返回d = gcd(a, b),并且找到ax + by = d的一个特解x,y。
    if (b == 0) { x = 1, y = 0; return a; }
    ll d = extend_gcd(b, a % b, y, x);
    y -= a / b * x;
    return d;
}


ll mod_inverse(ll B, ll C) {//返回B mod C的逆
    ll x, y;
    extend_gcd(B, C, x, y);//x可能是负数
    return (x % C + C) % C;
}

int main() {
    cin >> A >> B >> C;
    cout << (A * mod_inverse(B, C)) % C;
    return 0;
}//by wqs

c++代码(特别地,当C为质数的时候,可以使用费马小定理,不是通用法)

cpp 复制代码
#include<bits/stdc++.h>

using namespace std;

typedef long long ll;

ll A, B, C;

ll fastPow(ll a, ll b, ll mod) {
    if (b == 0) return 1 % mod;
    if (b == 1) return a % mod;
    ll k = fastPow(a, b / 2, mod);
    if (b % 2 == 0) return (k * k) % mod;
    else return (((k * k) % mod) * a) % mod;
}

ll mod_inverse(ll B, ll C) { return fastPow(B, C - 2, C); }

int main() {
    cin >> A >> B >> C;//前提C为质数
    cout << (A * mod_inverse(B, C)) % C;
    return 0;
}//by wqs

题目解析

之所以要求gcd(B,C) = 1,是因为gcd(B,C) != 1的时候会有多个答案,这是硬性要求,否则题目无解。

然后我们要对C分类讨论。

如果C是质数,一般使用费马小定理。

如果C不是质数,一般使用通用法拓展欧几里得算法。

一般涉及到除法取模,模值都是质数,费马小定理用的更多。

相关推荐
千禧皓月3 分钟前
【C++】基于C++的RPC分布式网络通信框架(二)
c++·分布式·rpc
zl_vslam6 分钟前
SLAM中的非线性优-3D图优化之轴角在Opencv-PNP中的应用(一)
前端·人工智能·算法·计算机视觉·slam se2 非线性优化
是苏浙20 分钟前
零基础入门C语言之C语言实现数据结构之顺序表应用
c语言·数据结构·算法
南汐汐月23 分钟前
重生归来,我要成功 Python 高手--day33 决策树
开发语言·python·决策树
AA陈超29 分钟前
虚幻引擎5 GAS开发俯视角RPG游戏 P07-08 点击移动
c++·游戏·ue5·游戏引擎·虚幻
星释36 分钟前
Rust 练习册 :Proverb与字符串处理
开发语言·后端·rust
lkbhua莱克瓦241 小时前
Java基础——常用算法3
java·数据结构·笔记·算法·github·排序算法·学习方法
小白程序员成长日记1 小时前
2025.11.07 力扣每日一题
数据结构·算法·leetcode
·白小白1 小时前
力扣(LeetCode) ——209. 长度最小的子数组(C++)
c++·算法·leetcode
工会主席-阿冰1 小时前
数据索引是无序时,直接用这个数据去画图的话,显示的图是错误的
开发语言·python·数据挖掘