hdu 1576 A/B 【扩展欧几里得】【逆元】
<题目链接>
<转载于 >>> >
A/B
每组数据有两个数n(0 <= n < 9973)和B(1 <= B <= 10^9)。
设(A/B)%9973 = K, 则A/B = k + 9973x (x未知), 因此A = kB + 9973xB,
又A%9973 = n, 所以kB%9973 = n, 故kB = n + 9973y (y未知)
故(k/n)B +(-y/n)*9973 = gcd(B,9973) = 1 ***注意这里相当于利用扩展欧几里得求逆元,所以要注意只有当a与b互质的时候才能够用欧几里得求逆元,即这里的gcd(B,9973)=1
根据扩展欧几里得求出x(也就是方程中的k/n), 再乘以个n,再取模。
#include <cstdio> #define m 9973 void extend_gcd(int a,int b,int &x,int &y) //扩展欧几里得模板
{
if(b==)
{
x=,y=;
return ;
}
extend_gcd(b,a%b,x,y);
int r=x;
x=y;
y=r-(a/b)*y;
} int main()
{
int n,b,t,x,y;
scanf("%d",&t); while(t--)
{
scanf("%d%d",&n,&b);
extend_gcd(b,m,x,y); //x=k/n(k为答案)
x=(x%m+m)%m;
printf("%d\n",(x*n)%m);
}
return ;
}
hdu 1576 A/B 【扩展欧几里得】【逆元】的更多相关文章
- hdu 1573 A/B (扩展欧几里得)
		
Problem Description 要求(A/B)%9973,但由于A很大,我们只给出n(n=A%9973)(我们给定的A必能被B整除,且gcd(B,9973)= 1). Input 数据的第一行 ...
 - 扩展欧几里得 hdu 1576
		
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1576 不知道扩展欧几里得的同学可以参考:https://blog.csdn.net/zhjchengf ...
 - hdu 5512 Pagodas 扩展欧几里得推导+GCD
		
题目链接 题意:开始有a,b两点,之后可以按照a-b,a+b的方法生成[1,n]中没有的点,Yuwgna 为先手, Iaka后手.最后不能再生成点的一方输: (1 <= n <= 2000 ...
 - HDU 5114  扩展欧几里得
		
题目大意:给你两个球的坐标 他们都往(1, 1)这个方向以相同的速度走,问你他们在哪个位置碰撞. 思路:这种题目需要把x方向和y方向分开来算周期,两个不同周期需要用扩展欧几里得来求第一次相遇. #in ...
 - [ACM] hdu 3923 Invoker (Poyla计数,高速幂运算,扩展欧几里得或费马小定理)
		
Invoker Problem Description On of Vance's favourite hero is Invoker, Kael. As many people knows Kael ...
 - poj 2891       扩展欧几里得迭代解同余方程组
		
Reference: http://www.cnblogs.com/ka200812/archive/2011/09/02/2164404.html 之前说过中国剩余定理传统解法的条件是m[i]两两互 ...
 - hdu_1576A/B(扩展欧几里得求逆元)
		
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1576 A/B Time Limit: 1000/1000 MS (Java/Others) Me ...
 - Intel Code Challenge Final Round (Div. 1 + Div. 2, Combined) C.Ray Tracing (模拟或扩展欧几里得)
		
http://codeforces.com/contest/724/problem/C 题目大意: 在一个n*m的盒子里,从(0,0)射出一条每秒位移为(1,1)的射线,遵从反射定律,给出k个点,求射 ...
 - Root(hdu5777+扩展欧几里得+原根)2015 Multi-University Training Contest 7
		
Root Time Limit: 30000/15000 MS (Java/Others) Memory Limit: 262144/262144 K (Java/Others)Total Su ...
 
随机推荐
- Git查看单个文件修改历史
			
1 命令 git log --pretty=oneline 文件名 ➜ admin git:(feature/v1.5.0_20181202_group) git log --pretty=onel ...
 - Mac下压力测试工具siege
			
安装: brew install siege 用法: siege -c 并发数 -t 运行测试时间 URL 如: siege -c 1000 -t 5S URL 这里要注意的是-t后面的时间要带单位, ...
 - 解决bootstrap-table多次请求只触发一次的问题
			
在初始化table之前,要将table销毁,否则会保留上次加载的内容 1 $("#table").bootstrapTable('destroy'); 2 $("#tab ...
 - Dom4j向XML中指定位置添加、删除、修改节点——(五)
			
需求: 在第一本书作者后面增加描述 <描述>好书</描述> 思路:获取书下面下的所有节点(一个list集合),在list集合指定位置添加一个元素(list.add(index ...
 - mysql 索引无法使用问题
			
今天碰到一个问题,表中有一个索引不使用,怎么强制也没用 ,force index都没用, 后来才发现是类型不对, 比如索引字段是int,如果参数使用varchar,那么是无法使用索引的,参数类型最好统 ...
 - oracle巡检脚本备份
			
重做日志生成情况,一天生成日志大小:select round(sum(blocks*block_size)/1024/1024/1024,2) BLOCK from v\$archived_log w ...
 - windows系统中搭建Jenkins服务器
			
1 须知 100.126.36.232等Jenkins服务器是通过设置代理访问外网,管理Jenkins和插件升级站点的,本地安装受黄区网络限制需要特殊配置,且有些插件无法下载. 前提条件: ...
 - 018_nginx_proxy死循环问题
			
今天线上遇到一个请求一次,触发多次的请求,而且直接把nginx机器压垮了.经排查,经过如下: 一. server{ server www.jyall.com; location /latestrele ...
 - 配置Sublime Text2的python运行环境(Sublime Text 3也类似)
			
1. 前言 用Sublime Text 2 配置Python运用环境,有简单配置还有像IDLE一样的配置,本文分成第一部分和第二部分. 2. 配置 第一部分(简单配置) 1.只需要打开Pref ...
 - Node.js随手笔记
			
参考文章:https://blog.csdn.net/IronKee/article/details/83780857 安装nvm的方法: 如果已经单独安装了node,建议卸载,然后继续向下看. 直接 ...