首先、扩展欧几里得定理:对于两个不全为0的整数a、b,必存在一组解x,y,使得ax+by==gcd(a,b);

int gcd(int a,intb)

{intt,d;if(b==0)

{

x=1;

y=0; //不明处1

returna;

}

d=gcd(b,a%b);

t=x;

x=y;

y=t-(a/b)*y; //不明处2

returnd;

}

x y 用全局变量表示

不明处1:由扩展欧几里得定理:ax+by==gcd(a,b)---式1,而此时b==0,也就是说gcd(a,0)==a。原式变为ax+by==a --> x==1,y==0。应该够清楚了吧

不明处2:这里先说明一下我的一些规则,x,y表示第一次递归时的值,x1,y1表示第二次递归时的值。那么

gcd(a,b)==gcd(b,a%b),同时都代入式1,有ax+by==b*x1+(a%b)*y1。将右边变形一下

b*x1+(a%b)*y1==b*x1+(a-(a/b)*b)*y1==a*y1+b*(x1-(a/b)*y1),最终得到ax+by==a*y1+b*(x1-(a/b)*y1)

也就是说,上一深度的x等于下一深度的y1,上一深度的y等于下一深度的x1-(a/b)*y1。    需要注意,上面推导时用的除法都是整型除法

那么对于一般的不定式ax+by==c,它的解应该是什么呢。很简单,x1=x*(c/gcd(a,b)),y1=y*(c/gcd(a,b))。

扩展的欧几里得(EXTENDED-EUCLID)

一、假设:

对于给定的整数a和b,它们满足方程:ax+by=d=gcd(a,b),求出整系数x,y

二、推理:

ax+by=gcd(a,b)=gcd(b,a%b)=bx+(a-(int)a/b*b)y=ay+b(x-(a-(int)a/b*y)

三、扩展的欧几里得算法:

1 int extended_gcd(int a, int b, int &x, int &y)

2 {

3 int ret, tmp;

4 if (!b) {

5 x = 1; y = 0; return a;

6 }

7 ret = extended_gcd(b, a % b, x, y);

8 tmp = x;

9 x = y;

10 y = tmp - a / b * y;

11 return ret;

12 }

四、应用:

1、求解模线性方程:ax≡b (mod n)

定理一:设d=gcd(a,n),用扩展欧几里得算法解线性方程 ax'+ny'=d.如果d|b,则方程axºb(mod n)有一个解的值x0=x'(b/d)mod n

定理二:方程axºb(mod n)有解(即存在d|b,其中d=gcd(a,n)),x0是该方程的任意一个解,则该方程对模n恰有d个不同的解,分别为

x(i)=x(0)+i(n/d)(i=1,2,...d-1)

//用扩展欧几里得解模线性方程ax=b (mod n)

bool modularLinearEquation(int a,int b,int n)

{

int x,y,x0,i;

int d=Extended_Euclid(a,n,x,y); //ax=b (mod n) 等价于ax+ny=b

if(b%d)

return false;

x0=x*(b/d)%n;

for(i=1;i<=d;i++)

printf("%d\n",(x0+i*(n/d))%n);

return true;

}

2、求乘法逆元:ax≡1(mod n)

ax≡1(mod n)等价于 ax+ny=1=gcd(a,n),调用extended_gcd(a,n,x,y),并当公约数ret=1(a,n互为质数,ret一定等于1)时,

当x>0时,x即为a的乘法逆元。当x<0时,将x转换为mod n的最小正整数即可:

while(x<0)

x+=n;

注:Java中没有指针,不能向C/C++这样调用;而C/C++可以使用指针或引用传出形参x,这个特性,使C/C++函数能返回多个值,而

Java方法最多只能返回一个值。那么在Java版本的实现中,可以将这里的x定义为一个类变量(static),这样就可以获取x的值了。

扩展欧几里得算法java_扩展欧几里得算法相关推荐

  1. 层次分析法java_层次分析法java实现

    做毕设时因为恐惧层次分析法的计算量,所以通过程序实现了. 层次分析法计算过程的程序化实现代码 package e_5_28; /* * author 曾绍涛 * time 2009-5-29 * fu ...

  2. 欧几里得算法、扩展欧几里得算法(特解、应用、通解)

    文章目录 1. 欧几里得算法(也叫辗转相除法) 1.1 直接上模拟 1.2 几何理解 1.3 用代数方法证明 g c d ( a , b ) = g c d ( b , a % b ) gcd(a, ...

  3. 【中级软考】什么是“敏捷过程的开发方法(敏捷方法agile)“(极限编程XP、特征驱动开发FDD、并列争球法Scrum、水晶法Crystal、开放源码法、自适应软件开发 ASD方法)

    文章目录 敏捷方法 1 极限编程 XP 1.四大价值观 2.十二个最佳实践 2 特征驱动开发 FDD 1.FDD 角色定义 2.核心过程 3.最佳实践 3 并列争球法 Scrum 1.Scrum 的五 ...

  4. 双亲表示法、孩子表示法、孩子兄弟表示法(二叉树表示法),森林和二叉树的转换

    树的存储结构 一.双亲表示法 二.孩子表示法(孩子链表) 三.孩子兄弟表示法(二叉树表示法.二叉链表表示法) 四.森林(树)和二叉树的转换 一.双亲表示法 实现:定义数组结构存放树的结点,每个结点含两 ...

  5. 结构力学计算机矩阵位移法,结构力学-矩阵位移法.ppt

    <结构力学-矩阵位移法.ppt>由会员分享,可在线阅读,更多相关<结构力学-矩阵位移法.ppt(42页珍藏版)>请在装配图网上搜索. 1.结构力学,2 / 42,第七节 平面刚 ...

  6. 算法分析五:回溯法与分⽀限界法

    一.回溯法 1. 基本思想与解题步骤 基本思想: 把问题的解空间转化成了图或者树的结构表⽰,然后使⽤深度优先搜索策略进⾏遍历,遍历的过程中记录和寻找所有可⾏解或者最优解. 解题步骤: 针对所给问题,定 ...

  7. 利用配方法引入特征根法来求解二阶递推通项

    利用配方法引入特征根法来求解二阶递推通项 引言 本文从配方法的角度引入特征法来求解二阶递推通项; 利用高中的知识水平便可以理解, 笔者观察相似文章皆是聚焦于通项的推导, 并未以思考的方式去回答为何做出 ...

  8. 机器学习(六)分类模型--线性判别法、距离判别法、贝叶斯分类器

    机器学习(六)分类模型--线性判别法.距离判别法.贝叶斯分类器 首先我们了解常见的分类模型和算法有哪些 线性判别法 简单来说就是用一些规定来寻找某一条直线,用直线划分学习集,然后根据待测点在直线的哪一 ...

  9. 三种图像内插法(最近邻内插法、双线性内插法、双三次内插法)的做法 代码实现

    参考博客 数字图像处理学习笔记(四)--数字图像的内插.度量.表示与质量_闭关修炼--暂退的博客-CSDN博客 数字图像处理学习笔记(七)--用Pycharm及MATLAB实现三种图像内插法(最近邻内 ...

最新文章

  1. Ubuntu 中的 dpkg 安装deb、删除deb、显示已安装包列表、解压deb文件、显示deb包内文件列表、配置deb软件包
  2. Codeforces 755B. PolandBall and Game 贪心
  3. 1)C++对象大小计算
  4. 东北真有“油炸冰溜子”这道菜吗?
  5. 计算机关闭后剪切板的内容会消失,关闭计算机电源后剪贴板的信息为什么会丢失...
  6. 数据采集无线网服务器软件,WIFI智能数据盒
  7. 2021-08-03 SELECT简单查询
  8. LM117,LM217,LM317;LM137,LM237,LM337
  9. navicat for mysql Mac版 中文免安装
  10. HTML+CSS+JS雷霆战机
  11. 分布式轻量级任务调度框架-XXL-JOB(最全面,附带本人实战)
  12. springboot+二手车交易系统 毕业设计-附源码131456
  13. 赚多多V10自动任务网抢单源码+会员自营版+教程
  14. 锂电池剩余寿命预测(简单介绍)
  15. luogu P1489 猫狗大战
  16. WACV2020:开源基于深度学习方法DeOccNet用来去除透视光场中的前景遮挡
  17. 免费视频制作工具满足非专业用户的视频处理需求:压缩视频、转码视频、倒放视频、合并片段、根据字幕裁切片段、自动配字幕、自动剪辑等
  18. c语言免杀花指令大全,免杀花指令
  19. Mybatis报错:There is no getter for property named 'xxxx' in 'class xxxx之解决办法
  20. TML转义字符:xss攻击与HTML字符的转义和反转义

热门文章

  1. [北大张铭 教学版]数据结构与算法(C++)
  2. python无角正方形代码_python学习,打印等腰直角三角形 实心正方形空心正方形...
  3. 一个TCP连接可以发多少个HTTP请求?
  4. 工科SCI论文的写作技巧(四) 写好引言
  5. wincc里vbs脚本
  6. 细胞自动机c语言源代码,关于细胞自动机的程序..求救!!谢谢!
  7. LabVIEW扫描成像或同步模拟电压生成和数据采集
  8. ie调用window.print批量打印数据表格。
  9. InfoGAN理论分析帖汇总
  10. 术业有专攻,越专业越值钱