输入两个正整数m和n,求其最大公约数和最小公倍数
时间: 2023-11-03 16:06:23 浏览: 64
最大公约数可以使用辗转相除法求解:
1. 令a = max(m, n),b = min(m, n);
2. 如果b等于0,则a就是最大公约数;
3. 否则,计算a除以b的余数r,令a = b,b = r,重复第二步。
最小公倍数可以通过最大公约数求解:
1. 计算m和n的最大公约数gcd;
2. 则m和n的最小公倍数为:m * n / gcd。
代码如下:
```python
def gcd(m, n):
if n == 0:
return m
return gcd(n, m % n)
m = int(input("请输入第一个正整数:"))
n = int(input("请输入第二个正整数:"))
# 计算最大公约数和最小公倍数
gcd_num = gcd(m, n)
lcm_num = m * n // gcd_num
print("最大公约数为:", gcd_num)
print("最小公倍数为:", lcm_num)
```
相关问题
输入两个正整数m和n求其最大公约数和最小公倍数
最大公约数可以使用辗转相除法来求解,具体步骤如下:
1. 比较m和n的大小,将较小的数赋值给a,较大的数赋值给b。
2. 计算a和b的余数c,如果c等于0,则b就是最大公约数;否则,将b赋值给a,将c赋值给b,继续执行第2步,直到c等于0为止。
最小公倍数可以通过最大公约数来求解,公式为:
最小公倍数 = m * n / 最大公约数
下面是Python代码实现:
```python
m = int(input("请输入第一个数:"))
n = int(input("请输入第二个数:"))
# 计算最大公约数
a = min(m, n)
b = max(m, n)
while a != 0:
c = b % a
b = a
a = c
gcd = b
# 计算最小公倍数
lcm = m * n // gcd
print("最大公约数为:", gcd)
print("最小公倍数为:", lcm)
```
C++输入两个正整数m和n求其最大公约数和最小公倍数
以下是C++代码实现:
```c++
#include <iostream>
using namespace std;
// 求最大公约数函数
int gcd(int a, int b) {
if (b == 0) {
return a;
}
return gcd(b, a % b);
}
// 求最小公倍数函数
int lcm(int a, int b) {
return a * b / gcd(a, b);
}
int main() {
int m, n;
cout << "请输入两个正整数m和n:" << endl;
cin >> m >> n;
// 求最大公约数
int max_common_divisor = gcd(m, n);
cout << "最大公约数为:" << max_common_divisor << endl;
// 求最小公倍数
int min_common_multiple = lcm(m, n);
cout << "最小公倍数为:" << min_common_multiple << endl;
return 0;
}
```
输入示例:
```
请输入两个正整数m和n:
36 48
```
输出示例:
```
最大公约数为:12
最小公倍数为:144
```
阅读全文