Problem Description

要求(A/B)%9973,但由于A很大,我们只给出n(n=A%9973)(我们给定的A必能被B整除,且gcd(B,9973) = 1)。

Input

数据的第一行是一个T,表示有T组数据。每组数据有两个数n(0 <= n < 9973)和B(1 <= B <= 10^9)。

Output

对应每组数据输出(A/B)%9973。

Sample Input

2
1000 53
87 123456789

Sample Output

7922
6060

解题思路:这道题有三种做法,①是扩展欧几里德算法,②是试探算法,③是乘法逆元。

解法一:可以用解整数的不定方程来解决,即使用扩展欧几里德算法。

根据题意,输入的n=A%9973(没有输入A),A%B=0(A必能被B整除),B与9973互质(gcd(B,9973)=1)。
设x=(A/B)%9973(x是最终想计算的值),则9973k+x=A/B(k为整数:(A/B)/9973),得A=9973Bk+xB。
因为n=A%9973与A=9973Bk+xB,所以xB%9973=n,得xB=n+9973y。故:(x/n)B+(-y/n)9973=1=gcd(B,9973),该方程有解。要求x和y,先求X=x/n和Y=-y/n,即先解方程BX+9973Y=1。最后,x=X*n。需要注意的是,求得的x有可能是负值,需要调整为正数,即x=(x+a)%a。

顺便推导一下扩展欧几里得算法的计算过程:假设ax+by=gcd(a,b),由欧几里得算法可得gcd(a,b)=gcd(b,a%b),即ax+by=bx1+(a%b)y1=bx1+(a-a/b*b)y1=ay1+b(x1-a/b*y1),由恒等定理可得x=y1,y=x1-a/b*y1,这样我们就得到了求解x,y的方法:系数x,y基于x1,y1。终止条件:当b=0时,a为最大公约数。这时只需保证a的系数即x=1即可,y取任何值都不会由影响,因为此时b=0,所以我们不妨假设y=0,exgcd先递归到最后再回溯回来计算每个状态下的x',y',最终就可求得系数x,y的值。

AC代码:

 #include<bits/stdc++.h>
using namespace std;
int exGcd(int a,int b,int &x,int &y)//exgcd算法
{
if(b==){x=;y=;return a;}//ecgcd的终止状态为a=gcd,b=0
int r=exGcd(b,a%b,x,y);//下一个状态:b*x1+(a%b)*y1=gcd(b,a%b),相当于欧几里得算法,先递归到b=0,然后返回每个状态下的公约数
int t=x;x=y;y=t-a/b*y;//x=y',y=x'-a/b*y'
return r;//返回当前的公约数给上一个状态
}
int main()
{
int t,n,b,x,y,a=;//a为质数
cin>>t;
while(t--){
cin>>n>>b;
exGcd(b,a,x,y);//方程:bx+ay=gcd(b,a)=1
//if(x<0)x+=a;
x=(x+a)%a;// x有可能为负,需要调整为正数
cout<<x*n%a<<endl;//A=m*B,x=m/n --> m=x*n,(A/B)%9973=(x*n*B/B)%9973=(x*n)%9973
}
return ;
}

解法二:试探法。根据题意,输入的n=A%9973(没有输入A),A%B=0(A必能被B整除),B与9973互质(gcd(B,9973)=1)。
设x=(A/B)%9973(x是最终想计算的值,满足0<=x<9973),则9973k+x=A/B(k为整数:(A/B)/9973),得A=9973Bk+xB。
因为n=A%9973与A=9973Bk+xB,所以xB%9973=n,得xB=n+9973y,亦得xB-n=9973y。故:(xB-n)%9973=0
需要注意的是,变量类型为long long。

AC代码:

 #include<bits/stdc++.h>
using namespace std;
int main()
{
int t;
long long n,b;//要用long long不然会溢出(n接近10的4次方,b接近10的9次方,取最大时已经超int)
cin>>t;
while(t--){
cin>>n>>b;
for(int x=;x<;x++)
if((x*b-n)%==){cout<<x<<endl;break;}//试探算法
}
return ;
}

解法三:乘法逆元。∵(A/B)%9973=A%9973*B-1%9973=n*B-1%9973,根据费马小定理a(p-1)≡1(mod p),即a*a(p-2)≡1(mod p),又由乘法逆元:ax≡1(mod p)可得x=a(p-2)%p=a-1%p(注意:p是质数,且p不能整除a(即gcd(a,p)=1),x为a关于模p的乘法逆元)∴最终可以推得n*B-1%p=n*B(p-2)%p(这里的p=9973),套一下整数快速幂模板即可。

AC代码:

 #include<bits/stdc++.h>
using namespace std;
typedef long long LL;
const int mod=;
LL mod_power(LL a,LL b){//整数快速幂
LL ans=;
while(b){
if(b&)ans=ans*a%mod;
a=a*a%mod;
b>>=;
}
return ans;
}
int main(){
int t;LL n,B;
while(cin>>t){
while(t--){
cin>>n>>B;
cout<<n*mod_power(B,mod-)%mod<<endl;//n*B^(p-2)%p
}
}
return ;
}

题解报告:hdu 1576 A/B(exgcd、乘法逆元+整数快速幂)的更多相关文章

  1. 【板子】gcd、exgcd、乘法逆元、快速幂、快速乘、筛素数、快速求逆元、组合数

    1.gcd int gcd(int a,int b){ return b?gcd(b,a%b):a; } 2.扩展gcd )extend great common divisor ll exgcd(l ...

  2. 题解报告:poj 3233 Matrix Power Series(矩阵快速幂)

    题目链接:http://poj.org/problem?id=3233 Description Given a n × n matrix A and a positive integer k, fin ...

  3. 【模拟题(电子科大MaxKU)】解题报告【树形问题】【矩阵乘法】【快速幂】【数论】

    目录: 1:一道简单题[树形问题](Bzoj 1827 奶牛大集会) 2:一道更简单题[矩阵乘法][快速幂] 3:最简单题[技巧] 话说这些题目的名字也是够了.... 题目: 1.一道简单题 时间1s ...

  4. 2017ACM暑期多校联合训练 - Team 2 1006 HDU 6050 Funny Function (找规律 矩阵快速幂)

    题目链接 Problem Description Function Fx,ysatisfies: For given integers N and M,calculate Fm,1 modulo 1e ...

  5. HDU 3923 Invoker(polya定理+乘法逆元(扩展欧几里德+费马小定理))

    Invoker Time Limit : 2000/1000ms (Java/Other)   Memory Limit : 122768/62768K (Java/Other) Total Subm ...

  6. HDU 5868 Different Circle Permutation Burnside引理+矩阵快速幂+逆元

    题意:有N个座位,人可以选座位,但选的座位不能相邻,且旋转不同构的坐法有几种.如4个座位有3种做法.\( 1≤N≤1000000000 (10^9) \). 题解:首先考虑座位不相邻的选法问题,如果不 ...

  7. HDU 5793 A Boring Question (找规律 : 快速幂+逆元)

    A Boring Question 题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=5793 Description Input The first l ...

  8. hdu 2604 Queuing dp找规律 然后矩阵快速幂。坑!!

    http://acm.hdu.edu.cn/showproblem.php?pid=2604 这题居然O(9 * L)的dp过不了,TLE,  更重要的是找出规律后,O(n)递推也过不了,TLE,一定 ...

  9. hdu 1757 A Simple Math Problem (矩阵快速幂,简单)

    题目 也是和LightOJ 1096 和LightOJ 1065 差不多的简单题目. #include<stdio.h> #include<string.h> #include ...

随机推荐

  1. 【APUE】文件I/O

    Linux的内核将所有外部设备都可以看做一个文件来操作.那么我们对与外部设备的操作都可以看做对文件进行操作.我们对一个文件的读写,都通过调用内核提供的系统调用:内核给我们返回一个file descri ...

  2. elasticsarch5.4集群安装

    越来越多的企业已经采用ELK解决方案来对其公司产生的日志进行分析,笔者最近着手在生产环境部署自己的ELK stack,本文介绍ELK中elasticsearch5.2集群的实现. 一.环境准备 1.系 ...

  3. php.ini中extension默许的地址到底在哪里设置的

    原文: http://www.myexception.cn/php/1436096.html ----------------------------------------------------- ...

  4. 自己定义控件 播放GIF动画

    watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQv/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/ ...

  5. android 浮动窗体学习笔记及个人理解(仿360手机助手)

    很感谢原文作者 http://blog.csdn.net/guolin_blog/article/details/8689140 经自己理解 程序执行界面例如以下图: 1.程序入口界面 2.小浮动窗体 ...

  6. 【bzoj1015】【JSOI2008】【星球大战】【并查集+离线】

    Description 非常久曾经.在一个遥远的星系,一个黑暗的帝国靠着它的超级武器统治者整个星系.某一天,凭着一个偶然的机遇,一支反抗军摧毁了帝国的超级武器.并攻下了星系中差点儿全部的星球.这些星球 ...

  7. 反射学习总结 --为理解SpringMVC底层做准备

    反射是什么? 通俗理解 - 照X光. java:一个类在反射面前就像照X光,清清楚楚明明白白. 应用:我们的ide中,能够"."一下就知道类中的所有方法就是通过反射实现的. XML ...

  8. Ios 项目从头开发 MVVM模式(三)

    1.话说,本来想做个聚合查询功能.可是我的重点想研究xmpp聊天功能.所以使用mvvm模式做了全然模式51job主界面的页面. 2.首先给大家看我执行起来的界面. 3.界面非常easy,做这个界面主要 ...

  9. NYOJ1026 阶乘末尾非0 【模板】

    阶乘末尾非0 时间限制:2000 ms  |  内存限制:65535 KB 难度:3 描写叙述 我们的问题非常是简单.n! 末尾非0数是几? 比方n=5的时候,n! =120,那么n!末尾非0数是2. ...

  10. MongoDB数据库的初识

    1,MongoDB是基于分布式文件存储的数据库,有c++语言编写,旨在为WEB应用提供可扩展的高效性能数据存储解决方案. MongoDB是一个介于关系型数据库和非关系数据库之间的产品,是非关系数据库当 ...