题记:这是我第四次审查扩展欧几里德原理,由于不经常使用。当你想使用,可以不记得细节,经常检查信息,所以,简单地梳理这一原则和扩展欧几里德的原则,以博客存档以备查用。

一个、欧几里德原理

欧几里德原理(Euclidean Theory)论中求两正整数最大公约数(Greatest Common Divisor, GCD)的方法。欧几里得原理在中国古代又称“辗转相除法”,这一称法揭示了其求最大公约数的过程。

对于两个正整数a,b。记其最大公约数为gcd (a,b)。

那么我们有 gcd (a,b) = gcd (b,a%b)

即a与b的最大公约数也是a除以b的余数与b的最大公约数。

欧几里得原理能够通过递归实现,以下给出事实上现的C代码:

int gcd(int a, int b)
{
if(b==0) return a;
return gcd(b,a%b);
}

函数返回參数a,b的最大公约数。注意该gcd函数调用时參数a,b不应该同一时候为0,否则该函数将不存在实际意义。

二、扩展欧几里得原理

欧几里得原理的扩展版本号最经典的使用方法在于求二元一次不定方程的整数解。

(1)先来看一个最简单的二元一次不定方程:

a*x + b*y = 1     (*),且 gcd (a,b) = 1,设它的一组整数解为 x = x1, y = y1。

对于还有一个二元一次不定方程:

b*x + (a%b)*y = 1    (**),设它的一组整数解为 x = x2, y = y2。

那么我们能够得到 a*x1 + b*y1 = b*x2 +(a%b)*y2 = 1,又由于 a%b = a - a/b*b。带入前式,

我们能够得到 a*x1 + b*y1 = a*y2 + b*(x2-a/b*y2)。因为a,b是随意的互质正整数。故可由该式得到方程(*)与方程(**)的解的关系例如以下:

x1 = y2。

y1 = x2-a/b*y2。即方程(*)的解可由方程(**)的解得到。

若我们想要求得a*x + b*y = 1的解,能够先求b*x + (a%b)*y = 1的解。我们能够发现这两个方程其未知量x,y 的系数之间是“辗转相除”的关系。

那么终于我们仅仅须要求gcd (a,b)*x + 0*y = 1的解(这里gcd (a,b) = 1,其解为 x = 1。y随意,一般取0),逆推之就可得到原方程的解。而逆推的过程就是扩展欧几里得原理的过程。

(2)我们如今已经攻克了求二元一次不定方程 a*x + b*y = 1, gcd (a,b) = 1的解。

以下考察二元一次不定方程的普通情况:

对于一般的二元一次方程 m*x + n*y = t,

  • 若gcd (m,n) | t,亦即 t%gcd(m,n) == 0。方程的解将与方程 (m/gcd(m,n))*x + (n/gcd(m,n))*y = t/gcd(m,n) 的解同样。

    记新方程为 a*x + b*y = d。那么其解将是方程 a*x + b*y = 1的d倍。

    而方程 a*x + b*y = 1, gcd(a,b) = 1的解在(1)中已经求得。

  • 否则方程无整数解

上述过程即使用扩展欧几里德原理一般寻求解决的整个过程简单二元不定方程。

版权声明:本文博客原创文章,博客,未经同意,不得转载。

欧几里德欧几里德原理和扩展的原则,(Euclidean Theory and Extended Euclidean Theory)学习笔记的更多相关文章

  1. 扩展欧几里得算法(exGCD)学习笔记

    @(学习笔记)[扩展欧几里得] 本以为自己学过一次的知识不会那么容易忘记, 但事实证明, 两个星期后的我就已经不会做扩展欧几里得了...所以还是写一下学习笔记吧 问题概述 求解: \[ax + by ...

  2. API/SPI可扩展设计原则(转)

    API/SPI可扩展设计原则 博客分类: [设计体系]架构模式 API/SPISPISPI原则JAVA SPISPI机制  写本篇主要是用来后面写一篇可扩展性软件设计打好基础(苦于找不到一篇关于API ...

  3. Springboot默认加载application.yml原理以及扩展

    Springboot默认加载application.yml原理以及扩展 SpringApplication.run(...)默认会加载classpath下的application.yml或applic ...

  4. Unity3D 骨骼动画原理学习笔记

    最近研究了一下游戏中模型的骨骼动画的原理,做一个学习笔记,便于大家共同学习探讨. ps:最近改bug改的要死要活,博客写的吭哧吭哧的~ 首先列出学习参考的前人的文章,本文较多的参考了其中的表述: 1. ...

  5. 机器学习实战(Machine Learning in Action)学习笔记————03.决策树原理、源码解析及测试

    机器学习实战(Machine Learning in Action)学习笔记————03.决策树原理.源码解析及测试 关键字:决策树.python.源码解析.测试作者:米仓山下时间:2018-10-2 ...

  6. ASP.NET MVC 学习笔记-7.自定义配置信息 ASP.NET MVC 学习笔记-6.异步控制器 ASP.NET MVC 学习笔记-5.Controller与View的数据传递 ASP.NET MVC 学习笔记-4.ASP.NET MVC中Ajax的应用 ASP.NET MVC 学习笔记-3.面向对象设计原则

    ASP.NET MVC 学习笔记-7.自定义配置信息   ASP.NET程序中的web.config文件中,在appSettings这个配置节中能够保存一些配置,比如, 1 <appSettin ...

  7. 并发编程学习笔记(14)----ThreadPoolExecutor(线程池)的使用及原理

    1. 概述 1.1 什么是线程池 与jdbc连接池类似,在创建线程池或销毁线程时,会消耗大量的系统资源,因此在java中提出了线程池的概念,预先创建好固定数量的线程,当有任务需要线程去执行时,不用再去 ...

  8. ZooKeeper学习笔记(二)——内部原理

    zookeeper学习笔记(二)--内部原理 1. zookeeper的节点的类型 总的来说可以分为持久型和短暂型,主要区别如下: 持久:客户端与服务器端断开连接的以后,创建的节点不会被删除: 持久化 ...

  9. 学习笔记:CentOS7学习之十五: RAID磁盘阵列的原理与搭建

    目录 学习笔记:CentOS7学习之十五: RAID磁盘阵列的原理与搭建 14.1 RAID概念 14.1.1 RAID几种常见的类型 14.1.2 RAID-0工作原理 14.1.3 RAID-1工 ...

随机推荐

  1. Java网络编程注意事项3

    如何使用POST请求和GET请求Web网站发送请求,下面的参考代码: import java.io.BufferedReader; import java.io.InputStream; import ...

  2. tomcatport占用,如何识别和kill

    开始-执行-cmd,进netstat -ano你可以看到整个port入住. 增加要想知道谁占用了我们的port8080,输入下面命令 C:\Documents and Settings\Adminis ...

  3. 付款页面DEMO

    watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQveHRxdWVlbg==/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA ...

  4. sqlserver不能直接create table as select

    sqlserver不能直接create table as select 在sqlserver 下想复制一张表的,想到oracle下直接create table xxx as select * from ...

  5. (大数据工程师学习路径)第二步 Vim编辑器----查找替换

    一.字符的替换及撤销(Undo操作) 1.替换和撤销(Undo)命令 替换和Undo命令都是针对普通模式下的操作 命令 说明 r+<待替换字母> 将游标所在字母替换为指定字母 R 连续替换 ...

  6. C++随机数的使用方法

         学过别的高级语言的都知道,产生随机数用的都是相似于random这种字符,c++也不例外,在C++中使用的是rand()函数,可是不同的是,假设在C++中仅仅使用了比如 "int i ...

  7. ASP.NET Identity

    使用ASP.NET Identity实现基于声明的授权 阅读目录 走进声明的世界 创建并使用声明 基于声明的授权 使用第三方来身份验证 小节 在这篇文章中,我将继续ASP.NET Identity 之 ...

  8. zoj2588 Burning Bridges --- 寻求尖端

    #include <iostream> #include <cstring> #include <string> #include <cstdio> # ...

  9. Php面向对象 – 继承和重写

    Php面向对象 – 继承和重写 承受: php于,通过类.使用特殊的经营宗旨. 通过定义类,采用extends来表示当前的类对象继承该类的对象. 样例: class C { public  $p_c  ...

  10. 工作介绍xml书包文件

    光开放平台一个非常重要的特点就是简化了对xml文件的操作,您能非常轻松地引入xml文件.定位到随意节点.增删属性和文本以及节点本身,以下咱们用实例来介绍对xml的操作 引入xml文件: <cht ...