博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
HDU 1576:A/B
阅读量:5892 次
发布时间:2019-06-19

本文共 1225 字,大约阅读时间需要 4 分钟。

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 
#include
#include
#include
#include
#include
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<
<

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

转载于:https://www.cnblogs.com/lightspeedsmallson/p/4785864.html

你可能感兴趣的文章
Windows下memcached的安装配置
查看>>
ubuntu: firefox+flashplay
查看>>
常见的海量数据处理方法
查看>>
Microsoft Windows 8.1 使用记录
查看>>
C语言博客作业03--函数
查看>>
web.xml 中CharacterEncodingFilter类的学习
查看>>
显示刚刚添加的最后一条数据,access,选择语句,select
查看>>
贪吃蛇逻辑代码
查看>>
实现c协程
查看>>
ASP.NET视频教程 手把手教你做企业论坛网站 视频教程
查看>>
[LeetCode] Meeting Rooms II
查看>>
从Swift学习iOS开发的路线指引
查看>>
3.1链表----链表(Linked List)入门
查看>>
[布局] bootstrap基本标签总结
查看>>
异步编程思想
查看>>
"数学口袋精灵"bug(团队)
查看>>
2017python第六天作业 面向对象 本节作业: 选课系统
查看>>
【找规律】Divide by Zero 2017 and Codeforces Round #399 (Div. 1 + Div. 2, combined) B. Code For 1...
查看>>
Scribes:小型文本编辑器,支持远程编辑
查看>>
为什么要使用 SPL中的 SplQueue实现队列
查看>>