,在Begin-End区域内进行代码补充,变量类型使用long long int。 输入: 两个正整数 输出: 最大公约数 最小公倍数 如果输入的数中包含负数,则输出Input Error
时间: 2024-03-01 13:53:02 浏览: 110
下面是完整的代码实现:
```
#include <stdio.h>
// 求最大公约数
long long int gcd(long long int a, long long int b) {
if (b == 0) {
return a;
} else {
return gcd(b, a % b);
}
}
// 求最小公倍数
long long int lcm(long long int a, long long int b) {
return a * b / gcd(a, b);
}
int main() {
long long int a, b;
// 读入两个正整数
scanf("%lld %lld", &a, &b);
// 判断输入是否合法
if (a <= 0 || b <= 0) {
printf("Input Error\n");
return 0;
}
// 调用gcd函数求最大公约数
long long int max_divisor = gcd(a, b);
// 调用lcm函数求最小公倍数
long long int min_multiple = lcm(a, b);
// 输出结果
printf("%lld %lld\n", max_divisor, min_multiple);
return 0;
}
```
输入两个正整数,程序会调用gcd和lcm函数分别求得它们的最大公约数和最小公倍数,最后输出结果。如果输入的数中包含负数,则输出Input Error。
阅读全文