C语言编程代码求两个整数的最大公约数和最小公倍数
时间: 2023-09-22 13:05:48 浏览: 190
好的,以下是求两个整数的最大公约数和最小公倍数的 C 语言代码:
```c
#include <stdio.h>
// 求两个数的最大公约数
int gcd(int a, int b) {
if(a < b) {
int temp = a;
a = b;
b = temp;
}
while(b != 0) {
int temp = a % b;
a = b;
b = temp;
}
return a;
}
// 求两个数的最小公倍数
int lcm(int a, int b) {
return a * b / gcd(a, b);
}
int main() {
int num1, num2;
printf("请输入两个整数:");
scanf("%d%d", &num1, &num2);
int max_common_divisor = gcd(num1, num2);
int min_common_multiple = lcm(num1, num2);
printf("%d和%d的最大公约数为%d\n", num1, num2, max_common_divisor);
printf("%d和%d的最小公倍数为%d\n", num1, num2, min_common_multiple);
return 0;
}
```
希望可以帮到你!
相关问题
c语言编程:求两个整数的最大公约数和最小公倍数。要求:用一个函数(func1)求最大公约数,函数(func2)求最小公倍数。在主函数中定义两个整数,调用函数func1和func2后,输出这两个整数的最大公约数和最小公倍数
下面是使用C语言编写的求两个整数的最大公约数和最小公倍数的代码:
```c
#include <stdio.h>
// 求两个数的最大公约数
int func1(int x, int y) {
int t;
while (y != 0) {
t = x % y;
x = y;
y = t;
}
return x;
}
// 求两个数的最小公倍数
int func2(int x, int y) {
int z = func1(x, y);
return x * y / z;
}
int main() {
int a, b;
printf("请输入两个整数:\n");
scanf("%d%d", &a, &b);
printf("最大公约数为:%d\n", func1(a, b));
printf("最小公倍数为:%d\n", func2(a, b));
return 0;
}
```
首先定义了两个函数 `func1` 和 `func2`,分别用于求两个整数的最大公约数和最小公倍数。其中,`func1` 使用了欧几里得算法(辗转相除法)求最大公约数,`func2` 则利用最大公约数求最小公倍数。
在主函数中,先读入两个整数,然后分别调用 `func1` 和 `func2` 函数求最大公约数和最小公倍数,并输出结果。
c语言求两个整数最大公约数和最小公倍数
以下是C语言求两个整数最大公约数和最小公倍数的代码示例:
1. 求最大公约数(辗转相除法)
```c
#include <stdio.h>
int main() {
int a = 0;
int b = 0;
scanf("%d %d", &a, &b);
int m = 0; while (m = a % b) {
a = b;
b = m;
}
printf("最大公约数为:%d\n", b);
return 0;
}
```
2. 求最小公倍数
```c
#include <stdio.h>
int main() {
int a = 0;
int b = 0;
scanf("%d %d", &a, &b);
int m = 0;
// 找出最小值
m = (a > b ? b : a);
// 假设m为最大公约数
while (1) {
if (a % m == 0 && b % m == 0) {
break;
}
m--;
}
printf("最大公约数为:%d\n", m);
printf("最小公倍数为:%d\n", a * b / m);
return 0;
}
```
阅读全文
相关推荐














