帮我写代码,在dev++中 输入两个正整数,求他们的最大公约数和最小公倍数
时间: 2024-10-10 14:10:35 浏览: 10
在Dev-C++环境中编写代码来计算两个正整数的最大公约数(GCD)和最小公倍数(LCM),可以使用欧几里得算法来找到GCD,然后通过GCD和其中一个数来计算LCM。下面是一个简单的示例:
```cpp
#include <iostream>
using namespace std;
// Function to find the greatest common divisor (GCD)
int gcd(int a, int b) {
if (b == 0)
return a;
else
return gcd(b, a % b);
}
// Function to find the least common multiple (LCM)
int lcm(int a, int b) {
return (a * b) / gcd(a, b);
}
int main() {
int num1, num2;
// 输入两个正整数
cout << "请输入第一个正整数: ";
cin >> num1;
cout << "请输入第二个正整数: ";
cin >> num2;
// 检查输入是否为正整数
if (num1 > 0 && num2 > 0) {
// 计算GCD和LCM
int result_gcd = gcd(num1, num2);
int result_lcm = lcm(num1, num2);
// 输出结果
cout << "这两个数的最大公约数(GCD): " << result_gcd << endl;
cout << "这两个数的最小公倍数(LCM): " << result_lcm << endl;
} else {
cout << "输入的数字必须是非负整数。" << endl;
}
return 0;
}
```