求x的最小正整数解,使得ax=b(mod m)

那么显然ax - b = m * y

ax - my = b

那么就套入Ax+By = K的不定方程中,然后用exgcd求解即可

但这道题求最大正整数解,对于一组解,有这样一个推论

x = x0 +k*(b/gcd(a,b)) 

y = y0-k*(a/gcd(a,b)) 

k为任意正整数 可以带入方程中算一下,依然满足方程。

那么也就是说x的变化幅度为b / gcd(a,b)

令d = gcd(a,b), B = b

那么最小正整数解就是 (x * (K / d)) % (B/d) + (B/d)) % (B/d)

x * (K / d)是一个解,然后模掉(B/d),也就是变成和0最近的解

如果是负数,再加上一个(B/d)就整数,然后再模一个(B/d)不会改变值

如果是整数,加上(B/d)再模(B/d)也不会改变值。

所以这样求出来的就是最小正整数解。

最后数论尽量用long long 保险一些,反正一般不开数组,只是开变量,不会耗很多空间,不开白不开。

#include<cstdio>
#include<cctype>
#define REP(i, a, b) for(int i = (a); i < (b); i++)
#define _for(i, a, b) for(int i = (a); i <= (b); i++)
using namespace std; typedef long long ll;
void read(ll& x)
{
int f = 1; x = 0; char ch = getchar();
while(!isdigit(ch)) { if(ch == '-') f = -1; ch = getchar(); }
while(isdigit(ch)) { x = x * 10 + ch - '0'; ch = getchar(); }
x *= f;
} void exgcd(ll a, ll b, ll& d, ll& x, ll& y)
{
if(!b) { d = a; x = 1; y = 0; }
else { exgcd(b, a % b, d, y, x); y -= x * (a / b); }
} int main()
{
ll a, b, m, x, y, d;
read(a); read(b); read(m);
ll A = a, B = -m, K = b;
exgcd(A, B, d, x, y);
if(K % d != 0) puts("no solution!");
else printf("%lld", ((x * (K / d)) % (B/d) + (B/d)) % (B/d));
return 0;
}

最新文章

  1. KendoUI系列:DropDownList
  2. win7登录后开机密码破解读取
  3. 关于js中的setTimeout和setInterval
  4. [转]Android 延迟执行
  5. HIHO线段树(成段)
  6. c 深度剖析 5
  7. block extends include三者的差别跟用法
  8. PartialView
  9. 让&lt;未将对象引用到实例&gt;见鬼去吧!
  10. Learning Django Resources
  11. 文件上传下载样式 --- bootstrap
  12. 使用阿里云集成包快速搭建LAMP+FTP教程
  13. JDBC操作数据库的学习(2)
  14. jsp常见jstl语法(二)
  15. 深入学习CSS外边距margin(重叠效果,margin传递效果,margin:auto实现块级元素水平垂直居中效果)
  16. 1363. ZigZag Conversion
  17. axios 取消请求的方法
  18. 11G新特性 -- Expression Statistics
  19. Linux第六周作业
  20. ant design table column 设置width不生效解决方案

热门文章

  1. python安装Redis数据库
  2. (2016北京集训十三)【xsy1531】魔法游戏 - Nim游戏
  3. 三、frpc 完整配置文件
  4. Linux 网络属性管理
  5. 数据结构实现(四)二叉查找树java实现
  6. JDBC、事务和连接池
  7. Sublime Text 3 Package Control安装
  8. HDU 4316 Contest 2
  9. oracle存储过程中使用execute immediate执行sql报ora-01031权限不足的问题
  10. UVALive - 2031 Dance Dance Revolution 三维dp