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;
}
全部评论

相关推荐

站队站对牛:还是浙江学校欢迎
投递海康威视等公司10个岗位
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
正在热议
更多
# 你的mentor是什么样的人? #
4588次浏览 33人参与
# 你觉得mentor喜欢什么样的实习生 #
10776次浏览 297人参与
# 未岚大陆求职进展汇总 #
38160次浏览 114人参与
# 帮我看看,领导说这话什么意思? #
6729次浏览 28人参与
# 26届秋招公司红黑榜 #
13421次浏览 44人参与
# 怎么给家人解释你的工作? #
1748次浏览 17人参与
# 智慧芽求职进展汇总 #
26075次浏览 110人参与
# 没有家庭托举的我是怎么找工作的 #
12806次浏览 161人参与
# 求职低谷期你是怎么度过的 #
5470次浏览 97人参与
# 实习必须要去大厂吗? #
146898次浏览 1542人参与
# 从哪些方向判断这个offer值不值得去? #
6825次浏览 95人参与
# 同bg的你秋招战况如何? #
158912次浏览 927人参与
# 度小满求职进展汇总 #
10248次浏览 53人参与
# 校招泡的最久的公司是哪家? #
4894次浏览 23人参与
# 面试紧张时你会有什么表现? #
1811次浏览 21人参与
# 你有哪些缓解焦虑的方法? #
37215次浏览 835人参与
# 你喜欢工作还是上学 #
77633次浏览 860人参与
# 入职第一天,你准备什么时候下班 #
85528次浏览 467人参与
# 秋招想进国企该如何准备 #
97761次浏览 487人参与
# 简历无回复,你会继续海投还是优化再投? #
103636次浏览 819人参与
# 机械人的工作环境真的很差吗 #
25100次浏览 119人参与
# 独居后,你的生活是更好了还是更差了? #
28161次浏览 263人参与
牛客网
牛客网在线编程
牛客网题解
牛客企业服务