~》》_《《~

咳咳!!!今天写此笔记,以防他日老年痴呆后不会解方程了!!!

  Begin !

~1~, 首先呢,就看到了一个 gcd(a,b),这是什么鬼玩意呢?什么鬼玩意并不重要,重要的她代表的含义,其实呢,gcd(a,b)就表示 非负整数 a 和 b(不同时为0) 的最大公约数,(数论概论上说:计算 a 与 b 的最大公因数的更低效方法是我女儿四年级老师教的方法,老师要求学生求出 a 与 b 的所有因数,然后找出同时出现在两个表中的最大数字。 YES!A good idea for 小学生!) 。如今呢,我们自然不能这样算啦!

好吧!从求 gcd (a,b) 开始!

  一般的有下列式子:

a = b * q1 + R1  ;

b = R1 *q2 + R2 ;

R1 = R2 * q3 + R3 ;

R2 = R3 * q4 + R4 ;

。。。。。。

。。。。。。

  这样写下去什么时候才是个头啊~_~。。。

  很显然 必然会有结束的地方的,因为肯定会有一个 R  为 0 (R2 >= R4 >= R6 ....,R1 >= R3 >= R5 ...),好吧,继续往下写:

Rn-1 = Rn * qn+1  +   Rn+1  ;

Rn = Rn+1 * qn+2  +  Rn+2 ;假设 Rn+2 == 0

。。。。。。。。。。。。。 ok!^_^  。。。。。。。。。。。。。。

Rn+2 = 0了,那么由最后一个式子得 Rn+1整除Rn,接着,Rn+1 整除 Rn-1,,,,很显然的,这个递推可以推到第一个式子,so,Rn+1 整除 a,Rn+1 整除 b, 也就是说 Rn+1 是 a 与 b 的公约数了,是不是最大的呢?先把 Rn+1 记为 g,设 d 为 a 与 b  的任意一个公约数,由第一个

式子(a = b * q1 + R1)可以知道,d 整除 R1 ,再代入到第二个式子里得, d 整除 R2,推啊推,推啊推,最后知道了 d 整除 Rn+1,即 d 整除 g,

因为 d 是任意的公约数 , d 整除 g ,那么 取 d 为 最大公约数,则 g 既是公约数,又是最大公约数的倍数,只能是 :g 就是最大公约数。

  在前面“,,,,递推 。。”里隐藏了一个惊天大秘密,那就是 gcd(a,b) = gcd(b,a%b),这个秘密啊,十分的奇妙!为啥有这个结论呢?从第一个式子(a = b * q1 + R1) 显然, gcd (a,b) = g; 再显然 gcd(b,r1) = g ; 。。。。。 显然嘛,gcd (a,b) = gcd(b,a%b),

 。。。。。。。。。。。ok。这个问题算是解决了。代码附上。。。。。。。。。。。。。。。。。。。

 int gcd(int a,int b)
{
return b==?a:gcd(b,a%b) ;
}

gcd

~2~,好吧,其实前面只是闲扯!不过我可以赌五毛钱前面的东西没有偏题!

  下面来正面解决这个问题:a*x + b*y = gcd(a,b) ;

  一般的有下列式子:

a = b * q1 + R1  ;     R1 = a - q1 * b ;

b = R1 *q2 + R2 ;    R2 = b - q2 * R1 ;

R1 = R2 * q3 + R3 ;   R3 = R1 - q3 * R2 ;

R2 = R3 * q4 + R4 ;

。。。。。。

  值得注意的是右边的式子。可以发现每一个 R 都可以表示成 a 和 b 的倍数(把R1记作 (1,-q1)),可以定义一个结构体 A, B(好吧,是两个),

A.x ,A.y 分别表示 a, b 的系数,初始化一下A = a = (1,0),B = b = (0,1), 那么,R1 = A - q1*B ; 可以看到下面还要用到R1,而且用不到 A 了,

直接 令 A = R1 多好呢! A = A - B*q1 ; 再看R2 , R2 = B - q2*R1 = B - q2*A ; 同样 令 B = R2;则 B = B - A*q2;下面 R3 = A - q3*B ;也就是

A = A - q3*B ;再接着: B = B - A*q 。。。。。。等等,什么时候终止呢?在“再看R2"之前,考虑这样一个问题,若 R1 == g 呢?显然这个时候就要终止了,伪代码如下:

while(1) {

  q = a/b;

  r = a%b;

  A = A - B*q;

  (a,b) = (b,a%b);

  (A,B) = (B,A) //这样更容易写代码

  if (a%b == 0) break;

}

: 0 需特判。

代码如下:

 void sol(int a,int b,int &g)
{
A.x = B.y = ;
A.y = B.x = ;
if (a == ) {
g = b ;
A.x = ;
A.y = ;
return ;
}
if (b == ) {
g = a;
A.x = ;
A.y = ;
return ;
}
Node C ;
int q, r ;
while () {
q = a/b ;
r = a%b ;
A.x = A.x - B.x*q;
A.y = A.y - B.y*q;
a = b;
b = r;
if (a%b == ) break;
C = A;
A = B;
B = C;
}
g = b ;
}

ex_gcd

  其实呢?还有一个代码比较简短,用的是递归,附上如下:

 void ex_gcd(int a,int b,int &g,int &x,int &y)
{
if (!b) {
g = a;
x = ;
y = ;
}
else {
ex_gcd(b,a%b,g,y,x) ;
y -= x*(a/b) ;
}
}

递归版的ex_gcd

显然, a*x+b*y = gcd(a,b)的解不止一个((x,y)),事实上,此方程的每一个解都可由 (x+k*(b/g),y-k*(a/g))得出,其中 k 可取任意整数。

数论学习笔记之解线性方程 a*x + b*y = gcd(a,b)的更多相关文章

  1. 五一DAY1数论学习笔记

    by ruanxingzhi 整除性 如果a能把b除尽,也就是没有余数,则我们称a整除b,亦称b被a整除.(不是除以,是整除!!) 记作:\(a|b\) |这个竖杠就是整除符号 整除的性质 自反性 对 ...

  2. 《Fluid Engine Development》 学习笔记1-求解线性方程组

    我个人对基于物理的动画很感兴趣,最近在尝试阅读<Fluid Engine Development>,由于内容涉及太多的数学问题,而单纯学习数学又过于枯燥,难以坚持学习(我中途放弃好多次了) ...

  3. ES6-个人学习笔记二--解构赋值

    第二期,解构赋值如果能够熟练应用确实是个十分方便的功能,但是过分的依赖和嵌套只会让代码理解和维护起来十分困难,是个体现高逼格的表达式呢~ 1,解构赋值的基础 //定义:es6运行按照一定模式,从数组或 ...

  4. mybatis 学习笔记 -详解mybatis 及实例demo

    快速入门1 要点: 首先明白mybatis 是什么 这是一个持久层的框架.之前叫做ibatis.所以,在它的代码中出现ibatis这个词的时候,不要感到惊讶.不是写错了,它确实就是这个样子的. 首先, ...

  5. linux学习笔记-10.解压与压缩

    1.gzip压缩 gzip a.txt 2.解压 gunzip a.txt.gzgzip -d a.txt.gz 3.bzip2压缩 bzip2 a 4.解压 bunzip2 a.bz2bzip2 - ...

  6. 1.JasperReports学习笔记1-了解JasperReports

    转自:http://www.blogjava.net/vjame/archive/2013/10/12/404908.html JasperReports是一个开源的java报表制作引擎,官网地址:h ...

  7. ES6学习笔记之解构赋值

    1.数组的解构赋值 简单用法 { // 旧 let a=1,b=3; //新 let [a,b]=[1,3]; console.log(a,b);// 1 3 } 只要等号两边的模式相同,左边的变量就 ...

  8. sql注入学习笔记 详解篇

    sql注入的原理以及怎么预防sql注入(请参考上一篇文章) https://www.cnblogs.com/KHZ521/p/12128364.html (本章主要针对MySQL数据库进行注入) sq ...

  9. C#学习笔记--详解委托,事件与回调函数

    .Net编程中最经常用的元素,事件必然是其中之一.无论在ASP.NET还是WINFrom开发中,窗体加载(Load),绘制(Paint),初始化(Init)等等.“protected void Pag ...

随机推荐

  1. JSON数据源提供多值参数的实现

    一.应用场景 (1)报表的数据内容需要根据某个参数进行过滤. (2)该参数是一个多值参数,即从一个下拉列表中选择一个或多个项目. (3)报表需要自动运行,因此参数必须有默认值. (4)参数默认值无法在 ...

  2. 封装properties从配置文件读取测试用例输入数据

    当每个测试用例都有输入数据,而且数据量比较大的情况,可以采取从文件读取 如果想让同一套测试用例能够适应相似的输入数据,如果直接代码里面来回切换回可能会漏,而且还需要debug检错 可以把一些公用的输入 ...

  3. JS根据登录的城市不同调用不同的内容

    这个思路就是通过js获取访问客户的IP地址,根据IP接口判断IP的所属城市 1.先引入ip接口的js文件,网上有很多,这里用的是新浪的(感谢新浪) <script type="text ...

  4. javascript进阶系列专题:作用域与作用域链

    字面意思,作用域是指变量和函数的作用范围,换言之,作用域决定了变量和函数的可见性和有效时间.javascript作用域是用函数来区分,与其他语言的大括号不同. for (var i=0; i<5 ...

  5. IE10、IE11和Microsoft Edge的Hack

    IE10.IE11和Microsoft Edge的Hack 随着Win10的推广,Microsoft Edge浏览器已经越来越普遍,但是IE11也是伴随其中,尾大不掉. 首先,了解一下概念,如下图:微 ...

  6. 16090202(剑灵GPA)

    [目标] 剑灵GPA [思路] 1 2 绘制角色DrawCall body 5526面片 2.1[第一个DrawCall]63 RT 这个DrawCall PS VS 参数列表 VS // // Ge ...

  7. 多线程完成socket

    //服务器端代码 public class Service { //服务器 public static void main(String[] args) { ServerSocket serverSo ...

  8. bzoj2006: [NOI2010]超级钢琴

    题意:给一个序列(n<=500000),要求选定k个不同区间,使得区间长度在L,R之间,并使得k个区间和之和最大,输出这个最大值. 刚拿到题的时候想的是,对于每个点,如果以它开头,那么之后的L- ...

  9. hdoj 5124lines

    题意:给你n条线段,求被最多的线段覆盖的点被覆盖的次数 解法:我们可以将一条线段[xi,yi]分为两个端点xi和(yi)+1,在xi时该点会新加入一条线段,同样的,在(yi)+1时该点会减少一条线段, ...

  10. 《Android深度探索》(卷1)HAL与驱动开发读后感:

    第一章:安卓系统移植与驱动开发概述 全书分为4篇,分别从搭建开发环境,Linux驱动和Android HAL的基础知识,开发Linux驱动的高级技术和分析典型的Linux驱动源代码4个方面介绍Andr ...