A/B

A/B
题面
在这里插入图片描述
题意
对于初学者而言,(a/b) mod p求解的时候不知道有逆元这个概念,而且也可能没学过快速幂。所以这个题目对这些人似乎变得很难。
知识点
(a/b)mod p 其中1/b可以用inv(b)来替换,那是因为inv(b)是b的逆元
求逆元的方法详解
a^(p-2) = inv(a) (mod p)(注意一下这个是三个横线不是两个横线的“=”)
简单记忆方法:
在这里插入图片描述
上面式子式费马小定理的公式,其中a是整数,p是质数,且a,p互质(即两者只有一个公约数1)
那么上式可以写成:a*a(p-2)≡1(mod p) 两边同时除以a(这个只是记忆方法并不说明这个式子成立)
即 a^(p-2)≡ 1/a(mod p)≡inv(a) (mod p)
再次敲一下黑板:其中a是整数,p是质数,且a,p互质(即两者只有一个公约数1)

现在问题就转化成怎样怎样求a^(p-2),一般这种数字非常大,所以一般题目会给它%p,所以会求inv(mod p)即可
inv(mod p)=a^(p-2)(mod p)

typedef long long ll
ll pow(ll a,ll b ,ll m){//b=p-2 m=p;
ll ans=1;
while(b){
if(b&1) ans=ans*a%m;
a=a*a%m;
b>>=1;
}
return ans;
}
pow(a,p-2,p);//这个函数的答案就是inv(mod p)

推荐一篇文章:数论学习
分析
(A/B)%9973=(Ainv(B))%9973=(A%9973(inv(B)%9973))%9973
AC代码

#include <cstdio>
#include <cstring>
#include <algorithm>
#include <iostream>
using namespace std;
typedef long long ll;
ll pow(ll a,ll b ,ll m){
ll ans=1;
while(b){
if(b&1) ans=ans*a%m;
a=a*a%m;
b>>=1;
}
return ans;
}
int main(){
ll t,inv,ant,n,b;
cin>>t;
while(t--){
cin>>n>>b;
inv=pow(b,9971,9973);
ant=n*(inv%9973)%9973;
cout<<ant<<endl;
}
return 0;
}
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值