利用辗转相除法求两个整数的最大公因数和最小公倍数
时间: 2023-09-23 20:04:45 浏览: 73
辗转相除法,也称欧几里得算法,是求两个非零整数最大公约数的一种方法。其基本思想是用较大的数除以较小的数,然后用余数代替较大的数,继续进行相同的操作,直到余数为零为止。此时,较小的数即为这两个数的最大公约数。
以下是利用辗转相除法求两个整数的最大公因数和最小公倍数的示例代码:
```python
def gcd(a, b):
while b:
a, b = b, a % b
return a
def lcm(a, b):
return a * b // gcd(a, b)
```
其中,gcd()函数用来计算最大公因数,lcm()函数用来计算最小公倍数。
例如,对于整数21和14,最大公因数为7,最小公倍数为42,可以通过以下代码计算得出:
```python
a = 21
b = 14
print("最大公因数:", gcd(a,b))
print("最小公倍数:", lcm(a,b))
```
输出结果为:
```
最大公因数: 7
最小公倍数: 42
```
相关问题
辗转相除法求两个正整数最大公约数和最小公倍数的代码python
以下是求两个正整数最大公约数和最小公倍数的辗转相除法代码:
```python
def gcd(a, b):
while b:
a, b = b, a % b
return a
def lcm(a, b):
return a * b // gcd(a, b)
```
其中,`gcd` 函数用于求最大公约数,`lcm` 函数用于求最小公倍数。辗转相除法的思路是用较小的数去除较大的数,然后用余数去除较小的数,一直重复这个过程,直到余数为 0 为止。此时,较小的数即为最大公约数,较大的数与最大公约数的乘积即为最小公倍数。
c语言 辗转相除法求两个正整数的最大公约数和最小公倍数。
辗转相除法是求两个正整数的最大公约数的一种常用方法,同时也可以用来求最小公倍数。以下是使用C语言实现辗转相除法求两个正整数的最大公约数和最小公倍数的代码:
```
#include <stdio.h>
int main() {
int m, n, t, e, gcd, lcm;
// 输入两个数
printf("请输入两个正整数:\n"); scanf("%d%d", &m, &n);
t = m * n;
// 为保证大的除小的,如果m<n,则做交换
if (m < n) {
int temp;
temp = m;
m = n;
n = temp;
}
// 辗转相除法求最大公约数
e = m % n;
while (e != 0) {
m = n;
n = e;
e = m % n;
}
gcd = n;
lcm = t / gcd;
printf("它们的最大公约数是: %d\n", gcd);
printf("它们的最小公倍数是: %d\n", lcm);
return 0;
}
```
在这个代码中,我们首先输入了两个正整数m和n,然后计算它们的乘积t。为了保证大的除小的,我们对m和n进行了交换。接着,我们使用辗转相除法求出了它们的最大公约数gcd,并根据最大公约数求出了最小公倍数lcm。最后,我们输出了它们的最大公约数和最小公倍数。