利用辗转相除法求两个自然数的最大公因数 程序如下:
[size=xx-large]
//利用辗转相除法求两个自然数的最大公因数
int gcd(int a, int b)
{
int r;
while(b)
{
r = a%b;
a = b;
b = r;
}
return a;
}
相关理论如下:
「辗转相除法」又叫做「欧几里得算法」,是公元前 300 年左右的希腊数学家欧几里得在他的著作《几何原本》提出的。利用这个方法,可以较快地求出两个自然数的最大公因数,即 HCF 或叫做 gcd。所谓最大公因数,是指几个数的共有的因数之中最大的一个,例如 8 和 12 的最大公因数是 4,记作 gcd(8,12)=4。
在介绍这个方法之前,先说明整除性的一些特点,注以下文的所有数都是正整数,以后不再重覆.
我们可以这样给出整除以的定义:
对於两个自然数 a 和 b,若存在正整数 q,使得 a=bq,则 b 能整除 a,记作 b | a,我们叫 b 是 a 的因数,而 a 是 b 的倍数。那麼如果 c | a,而且 c | b,则 c 是 a 和 b 的公因数。
由此,我们可以得出以下一些推论:
推论一:如果 a | b,若 k 是整数,则 a | kb。因为由 a | b 可知 ha=b,所以 (hk)a=kb,即 a | kb.
推论二:如果 a | b 以及 a | c,则 a | (b±c)。因为由 a | b 以及 a | c,可知 ha=b,ka=c,二式相加,得 (h+k)a=b+c,即 a | (b+c).同样把二式相减可得 a | (b-c)。
推论三:如果 a | b 以及 b | a,则 a=b。因为由 a | b 以及 b | a,可知 ha=b,a=kb,因此 a=k(ha),hk=1,由於 h 和 k 都是正整数,故 h=k=1,因此 a=b。
辗转相除法是用来计算两个数的最大公因数,在数值很大时尤其有用而且应用在电脑程式上也十分简单。其理论如下:
如果 q 和 r 是 m 除以 n 的商及余数,即 m=nq+r,则 gcd(m,n)=gcd(n,r)。 证明是这样的:
设 a=gcd(m,n),b=gcd(n,r)
则由 a | m 及 a | n,可得 a | (m-nq)(由推论一及推论二得出的),即 a | r ,又 a | n,所以 a | b。
由 b | r 及 b | n,可得 b | (nq+r),即 b | m,又 b | n,所以b | a。
因为 a | b 并且 b | a,所以 a=b,即 gcd(m,n)=gcd(n,r)。
举例计算 gcd(546, 429),由於 546=1(429)+117,429=3(117)+78,117=1(78)+39,78=2(39),因此
gcd(546, 429)
=gcd(429, 117)
=gcd(117, 78)
=gcd(78, 39)
=39
此处再添加一个程序例子,不过不是利用辗转相除法
求最大公约数和最小公倍数:
#include <iostream>
using namespace std;
int gec,lcm;
void process(int x,int y)
{
gcd=x<y?x:y;
lcm=x<y?y:x;
for(gcd=x<y?x:y;gcd>1;gcd--)if(x%gcd==0&&y%gcd==0)break;
for(lcm=x<y?x:y;lcm>1;lcm++)if(lcm%x==0&&lcm%y==0)break;
return;
}
[/size]
分享到:
相关推荐
在数学中,两个或多个整数共有的约数中最大的一个称为最大公约数,而能同时被几个整数整除的最小的正整数称为最小公倍数。程序中使用了辗转相除法(也称欧几里得算法)来求最大公约数,通过一个循环结构不断将除数和...
最后一题讨论了两个正整数的最大公约数和最小公倍数的计算方法。最大公约数的计算采用辗转相除法,即欧几里得算法,不断用大数除以小数,再用上一步的小数除以上一步的余数,直到余数为0,此时的除数即为最大公约数...
这个问题是典型的最大公约数和最小公倍数问题,可以使用辗除法来解决,辗除法是一种寻找最大公约数和最小公倍数的方法。 程序 7:输入一行字符,分别统计出其中英文字母、空格、数字和其它字符的个数。 这个问题是...
最大公约数是两个或多个整数共有的约数中最大的一个。解决这个问题常用的方法是欧几里得算法,也称为辗转相除法。然而,给出的代码片段并不完整,但通常会使用一个循环结构,不断用较大的数除以较小的数,然后将较小...
对于任意两个正整数m和n,它们的最大公约数可以通过辗转相除法(也称欧几里得算法)来高效计算。而最小公倍数可以通过m*n除以最大公约数来得到。这个题目涉及到对算法效率和数学原理的理解。 #### 题目七:字符分类...
- 通过辗转相除法求最大公约数:不断用大数除以小数,再用小数除以上一次得到的余数,直到余数为0,此时的小数即为最大公约数。 - 最小公倍数可以通过两个数的乘积除以它们的最大公约数得到。
**程序分析**:虽然给定的文件没有提供具体的代码实现,但通常求两个数的最大公约数可以使用欧几里得算法,而最小公倍数可以通过两个数的乘积除以它们的最大公约数来得到。具体实现可能涉及循环和条件判断,以确定两...
有多种方法可以计算最大公约数,如欧几里得算法,这是一种基于除法的迭代算法,原理是两个数的最大公约数等于其中较小数和两数相除余数的最大公约数。 现在,结合这两个概念,我们可以构建一个程序,首先接收用户...
### JAVA编程题知识点详解 #### 知识点一:菲波那契数列与递归原理(程序1) **背景介绍:** 菲波那契数列(Fibonacci sequence)...- **辗转相除法**:一种求最大公约数的传统算法,适用于手动计算和简单程序实现。
- 最大公约数(GCD)是指两个或多个整数共有约数中最大的一个。 - **最小公倍数**: - 最小公倍数(LCM)是指能同时被几个整数所整除的最小正整数。 - **实现方法**: - 给定的程序6中使用了辗转相除法来计算最大公...
两个数的乘积等于它们的最大公约数和最小公倍数的乘积。求最小公倍数(LCM)时,如果知道GCD,可以使用公式LCM = (m * n) / GCD(m, n)。 7. **字符统计**:读入一行字符,通过循环遍历并使用条件判断统计字母、空格、...
**题目描述**:本题要求用户输入两个正整数,然后输出这两个数的最大公约数和最小公倍数。 **代码分析**: ```java import java.util.Scanner; public class lianxi06 { public static void main(String[] args) ...
最大公约数(GCD)是两个或多个整数共有的最大的正约数;最小公倍数(LCM)是能同时被几个整数整除的最小正整数。 #### 实现代码 ```java import java.util.Scanner; public class Lianxi06 { public static void...
此题要求计算两个数的最大公约数和最小公倍数。首先定义了一个名为`deff`的类,其中包含一个静态方法`deff`用于计算最大公约数。该方法使用欧几里得算法,即辗转相除法,通过`while`循环不断求余,直至余数为0时返回...
6. **最大公约数与最小公倍数**:第六题要求计算两个正整数的最大公约数(GCD)和最小公倍数(LCM)。GCD可以通过辗转相除法(欧几里得算法)求得,LCM通常是两个数乘积除以GCD的结果。 7. **字符分类计数**:第七...
求最大公约数(GCD)和最小公倍数(LCM)通常使用欧几里得算法,通过不断用较大数除以较小数并交换余数,直到余数为0,此时较小数即为GCD。LCM可以通过两数相除的商乘以GCD得到。 【程序7】 统计输入字符串中的字符...