用Java写一个程序,给定2个正整数,求它们的最大公约数和最小公倍数,并输出,输入格式: 输入有若干组。 每组数据,在一行中给出两个正整数M和N(≤1000),中间有1个空格。
时间: 2023-11-12 20:27:10 浏览: 41
import java.util.Scanner;
public class Main {
public static void main(String[] args) {
Scanner scanner = new Scanner(System.in);
while (scanner.hasNext()) {
int m = scanner.nextInt();
int n = scanner.nextInt();
int gcd = gcd(m, n);
int lcm = lcm(m, n);
System.out.println(gcd + " " + lcm);
}
}
// 求最大公约数
public static int gcd(int m, int n) {
if (n == 0) {
return m;
} else {
return gcd(n, m % n);
}
}
// 求最小公倍数
public static int lcm(int m, int n) {
return m * n / gcd(m, n);
}
}
相关问题
java给定2个正整数,求它们的最大公约数和最小公倍数,并输出。
最大公约数是指能同时整除两个数的正整数中最大的那个数。而最小公倍数是指能同时被两个数整除的最小的正整数。
求最大公约数的方法之一是使用欧几里得算法,原理是两个正整数的最大公约数等于它们的余数与除数的最大公约数。步骤如下:
1. 假设两个正整数为a和b,其中a > b。
2. 计算a除以b的余数r。
3. 若r为0,则b即为最大公约数。
4. 若r不为0,则用b替换a,用r替换b,再次执行步骤2。
5. 重复上述步骤直到余数为0,最后得到的b即为最大公约数。
求最大公约数的Java代码如下:
```java
public class GCD {
public static int findGCD(int a, int b) {
if (b == 0) {
return a;
} else {
return findGCD(b, a % b);
}
}
public static void main(String[] args) {
int num1 = 24;
int num2 = 36;
int gcd = findGCD(num1, num2);
System.out.println("最大公约数:" + gcd);
}
}
```
对于最小公倍数,可以利用最大公约数的性质得到,即两个数的最小公倍数等于它们的乘积除以最大公约数。最小公倍数的求解代码如下:
```java
public class LCM {
public static int findLCM(int a, int b) {
int gcd = GCD.findGCD(a, b);
int lcm = (a * b) / gcd;
return lcm;
}
public static void main(String[] args) {
int num1 = 24;
int num2 = 36;
int lcm = findLCM(num1, num2);
System.out.println("最小公倍数:" + lcm);
}
}
```
以上代码给定的两个正整数分别为24和36,最大公约数为12,最小公倍数为72。
python给定两个正整数,求它们的最大公约数和最小公倍数
### 回答1:
最大公约数可以使用辗转相除法或欧几里得算法来求解,具体步骤如下:
1. 用较大数除以较小数,得到余数
2. 如果余数为0,则较小数即为最大公约数
3. 如果余数不为0,则用较小数除以余数,得到新的余数
4. 重复步骤2和3,直到余数为0,此时较小数即为最大公约数
最小公倍数可以通过最大公约数来求解,具体公式为:
最小公倍数 = 两数之积 / 最大公约数
例如,给定两个正整数a=12和b=18,求它们的最大公约数和最小公倍数:
1. 用18除以12,得到余数6
2. 用12除以6,得到余数0,此时12即为最大公约数
3. 最小公倍数 = 12 * 18 / 12 = 18
因此,12和18的最大公约数为12,最小公倍数为18。
### 回答2:
求两个正整数的最大公约数和最小公倍数是数学中的基本问题。在Python中,可以使用辗转相除法和最小公倍数公式来求解这个问题。
首先,来介绍辗转相除法。它也叫欧几里德算法,步骤如下:
1. 用较小的数去除较大的数,得到余数和一个新的除数
2. 用刚才的除数去除余数,再得到余数和一个新的除数
3. 重复以上步骤,直到余数为0,此时余数的前一个数就是最大公约数
下面是使用Python实现辗转相除法的代码:
```python
def gcd(a, b):
while b:
a, b = b, a % b
return a
```
接下来是最小公倍数的求解。它的公式如下:最小公倍数=两数之积/最大公约数。结合刚才求出的最大公约数,我们可以利用Python来实现最小公倍数的计算:
```python
def lcm(a, b):
return a * b // gcd(a, b)
```
最后,我们可以编写一个程序来输出给定两个正整数的最大公约数和最小公倍数。代码如下:
```python
a = int(input("请输入第一个正整数:"))
b = int(input("请输入第二个正整数:"))
print("最大公约数为:", gcd(a, b))
print("最小公倍数为:", lcm(a, b))
```
使用上述代码,我们就可以求出两个正整数的最大公约数和最小公倍数了。
### 回答3:
最大公约数,即两个正整数中共有的约数中最大的一个。最小公倍数,即两个正整数中共有的倍数中最小的一个。
求最大公约数:
1. 辗转相除法:
辗转相除法又称为欧几里得算法,使用较为广泛。具体步骤如下:
(1)用两个正整数中较小的数去除较大的数,再用余数去除小的数,如此循环,直到余数为0为止,此时小的数即为最大公约数。
(2)若两个数中有一个为0,另一个不为0,则最大公约数为不为0的那个数。
Python代码实现:
```
def gcd(a, b):
if a < b:
a, b = b, a # 若a小于b,则交换a,b的值
while b: # 当b非零时,执行下面的操作
a, b = b, a % b # 每次将b赋值给a,将a%b的值赋给b
return a
```
2. 更相减损法:
更相减损法也是一种求最大公约数的方法。具体步骤如下:
(1)用两个正整数中较大的数减去较小的数,然后对差取绝对值再执行相同的操作,直到两个数相等为止。
(2)若两个数中有一个为0,另一个不为0,则最大公约数为不为0的那个数。
Python代码实现:
```
def gcd(a, b):
if a < b:
a, b = b, a # 若a小于b,则交换a,b的值
while b: # 当b非零时,执行下面的操作
a, b = b, abs(a - b) # 每次将b赋值给a,将|a-b|的值赋给b
return a
```
求最小公倍数:
最小公倍数可以通过公式 lcm(a, b) = a * b / gcd(a, b) 求出。
Python代码实现:
```
def lcm(a, b):
return a * b // gcd(a, b) # 注意要取整除 //,而不是普通除 /
```
完整代码实现:
```
def gcd(a, b):
if a < b:
a, b = b, a # 若a小于b,则交换a,b的值
while b: # 当b非零时,执行下面的操作
a, b = b, a % b # 每次将b赋值给a,将a%b的值赋给b
return a
def lcm(a, b):
return a * b // gcd(a, b) # 注意要取整除 //,而不是普通除 /
a, b = 12, 18
print("最大公约数:", gcd(a, b))
print("最小公倍数:", lcm(a, b))
```
运行结果:
最大公约数: 6
最小公倍数: 36