HDU 1576 A/B(欧几里得)
来源:互联网 发布:c语言判断字母大小写 编辑:程序博客网 时间:2024/05/23 21:11
思路:设(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
扩展欧几里得 求出k/n, 再乘以个n,记得取模
#include <iostream>#include <cstdio>using namespace std;const int MOD = 9973;void exgcd(int a, int b, int &x, int &y){ if(!b) { x = 1, y = 0; return ; } exgcd(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); exgcd(b, MOD, x, y); x = (x%MOD+MOD) % MOD; printf("%d\n",(x*n)%MOD); } return 0;}
1 0
- HDU 1576 A/B (扩展欧几里得)
- hdu 1576 A/B(扩展欧几里得)
- HDU 1576 A/B(拓展欧几里得)
- HDU - 1576 A / B(扩展欧几里得)
- HDU 1576 A/B(拓展欧几里得)
- 【HDU】1576 - A/B(扩展欧几里得)
- HDU 1576 A/B(欧几里得)
- hdu 1576 A/B(扩展欧几里得)
- hdu 1576 A/B(扩展欧几里得)
- HDU 1576 A/B (扩展欧几里得应用)
- HDU 1576-A/B(拓展欧几里得算法)
- HDU 1576 A/B (逆元求扩展欧几里得)
- HDU 1576 A/B(扩展欧几里得算法)
- hdu 1576 A/B(乘法逆元,扩展欧几里得)
- HDU - 1576 - A/B (扩展欧几里得定理)
- HDU 1576 A/B(拓展欧几里得,模板题)
- hdu 1576 拓展欧几里得 (乘法逆元) A/B
- HDU 1576 A/B(扩展欧几里得,思维)
- angular.js学习(2)--service和provider
- 汉诺塔C++实现(递归调用)
- 负载均衡之Haproxy配置详解
- 比赛总结+近期总结
- 120-pathsum
- HDU 1576 A/B(欧几里得)
- Python可迭代对象中的添加和删除(add,append,pop,remove,insert)
- win8.1忘记网络密码
- 1042 数字0-9的数量(数位DP)
- java基础——try catch final
- JAVA web中的一点东西
- struts2 spring4 hibernate4(s2sh)整合开发--简单实体的增删改查操作
- SIFT算法核心思想
- 求定积分的通用函数