博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
[模板]欧几里得算法/扩展欧几里得
阅读量:5279 次
发布时间:2019-06-14

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

最大公因数(欧几里得算法)

$gcd(a,b)=gcd(b\%a,a)$(不一定需要a<b)

$gcd(0,b)=b$

1 inline int gcd(int a,int b){2     return a==0?b:gcd(b%a,a);3 }

扩展欧几里得

寻找$ax+by=gcd(a,b)$的一组解x,y(一定存在整数解)

$ax+by=gcd(a,b)=gcd(b\%a,a)=(b-\lfloor\frac{b}{a}\rfloor*a)x'+ay'$

所以有一组解$x=y'-\lfloor\frac{b}{a}\rfloor*x',y=x'$

用此法可解同余方程$ax=b(\mod c)$,只要把$ax+cy=b$两边同除$b/gcd(a,c)$即可,所以有解的条件是$gcd(a,c)|b$

1 inline ll exgcd(ll a,ll b,ll &x,ll &y){2     if(!a){3         y=1;return b;4     }else{5         ll t=exgcd(b%a,a,x,y);6         y-=(b/a)*x;swap(x,y);7         return t;8     }9 }

 

转载于:https://www.cnblogs.com/Ressed/p/10089108.html

你可能感兴趣的文章
如何快速掌握一门技术
查看>>
利用AMPScript获取Uber用户数据的访问权限
查看>>
vagrant 同时设置多个同步目录
查看>>
python接口自动化28-requests-html爬虫框架
查看>>
生成随机数的模板
查看>>
Mysql 数据库操作
查看>>
转:linux终端常用快捷键
查看>>
UVa 11059 最大乘积
查看>>
数组分割问题求两个子数组的和差值的小
查看>>
composer 报 zlib_decode(): data error
查看>>
hdu 3938 并查集
查看>>
《深入分析Java Web技术内幕》读书笔记之JVM内存管理
查看>>
python之GIL release (I/O open(file) socket time.sleep)
查看>>
软件开发与模型
查看>>
161017、SQL必备知识点
查看>>
kill新号专题
查看>>
MVC学习系列——Model验证扩展
查看>>
字符串
查看>>
vue2.x directive - 限制input只能输入正整数
查看>>
实现MyLinkedList类深入理解LinkedList
查看>>