A/B

Time Limit: 1000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)

Total Submission(s): 2811    Accepted Submission(s): 2079

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=9973*X+n      (1)

求的y=(A/B)%9973翻译过来就是A/B=9973*Z+y    (2),注意这里咱们要求的是y

通过(1)(2)式,因为A不知道,所以要把A消掉。(真有一种做高中题目的感觉。。。)得到的方程整理即是

9973*(Z*B-X) +B*y = n

已知中说了gcd(9973,B)=1,太好了这个条件。因为咱们对(Z*B-X) 这一部分不关注,只求y。所以把(Z*B-X)当成一个未知数就可以了,一个扩展欧几里德就A掉。

代码:

#include <iostream>
#include <vector>
#include <string>
#include <cstring>
#include <algorithm>
#include <cmath>
using namespace std; int xx,yy,yue;
int a,b,d; void ex_gcd(int a,int b, int &xx,int &yy)
{
if(b==0)
{
xx=1;
yy=0;
yue=a;
}
else
{
ex_gcd(b,a%b,xx,yy); int t=xx;
xx=yy;
yy=t-(a/b)*yy; }
} int main()
{
int test;
cin>>test; while(test--)
{
long long n,B;
cin>>n>>B; ex_gcd(9973,B,xx,yy);
yy=yy*n;
yy=(yy%9973+9973)%9973;
cout<<yy<<endl;
}
return 0;
}

版权声明:本文为博主原创文章,未经博主允许不得转载。

最新文章

  1. python 学习笔记7 面向对象编程
  2. centos上安装php运行环境
  3. messagePaneHost
  4. iOS学习20之UIView
  5. bash
  6. Mysql-学习笔记(==》集合函数与分组四)
  7. HDU 1203 I NEED A OFFER!(01 背包DP)
  8. AUC计算方法总结
  9. Java面向对象的理解
  10. 初识JDBC
  11. 20175120彭宇辰 《Java程序设计》第八周学习总结
  12. 移动端目标识别(2)——使用TENSORFLOW LITE将TENSORFLOW模型部署到移动端(SSD)之TF Lite Developer Guide
  13. iOS通过URL构建UIImage
  14. CSS3的新增选择器
  15. CentOS 7使用yum安装PHP5.6
  16. 规范命名CSS
  17. 【atcoder F - Namori】**
  18. ASP.NET 5 Beta5来了(翻译)
  19. 统计学习方法笔记 -- KNN
  20. JavaScript高级程序设计-读书笔记(1)

热门文章

  1. PCIE_DMA:xapp1052学习笔记
  2. Metasploit学习笔记——社会工程学
  3. IOS 常用功能代码
  4. 五 Hibernate的其他API,Query&amp;Criteria&amp;SQLQuery
  5. mac flutter 创建过程及遇到的问题
  6. CC26XX开发
  7. Ubuntu安装Orcale
  8. python多进程编程中常常能用到的几种方法
  9. 015、MySQL取今天是第几季度,往后几个月是第几季度
  10. pyhton matplotlib可视化图像基础(二维函数图、柱状图、饼图、直方图以及折线图)