C语言while结构设计三个正整数的最小公倍数
时间: 2023-05-22 16:01:39 浏览: 80
以下是C语言while结构设计三个正整数的最小公倍数的代码:
```
#include <stdio.h>
int main() {
int a, b, c, i = 1, lcm;
printf("请输入三个正整数:\n");
scanf("%d %d %d", &a, &b, &c);
while (1) {
lcm = a * i * i + b * i + c;
if (lcm % a == 0 && lcm % b == 0 && lcm % c == 0) {
printf("三个数的最小公倍数为:%d\n", lcm);
break;
}
i++;
}
return 0;
}
```
这个程序使用while循环来计算三个正整数的最小公倍数。输入三个正整数后,程序会不断地增加一个计数器i,计算出当前的最小公倍数,直到找到一个能同时被三个数整除的最小公倍数为止。
相关问题
C语言两个正整数最大公约数和最小公倍数
以下是两种C语言求两个正整数最大公约数和最小公倍数的方法:
方法一:使用全局变量
```c
#include <stdio.h>
int gcd, lcm; // 最大公约数和最小公倍数设为全局变量
// 求最大公约数
void getGcd(int x, int y) {
int t;
if (x < y) {
t = x;
x = y;
y = t;
}
do {
t = x % y;
if (t != 0) {
x = y;
y = t;
t = x % y;
}
} while (t != 0);
gcd = y;
}
// 求最小公倍数
void getLcm(int x, int y) {
getGcd(x, y);
lcm = x * y / gcd;
}
int main() {
int x, y;
printf("请输入两个正整数:");
scanf("%d,%d", &x, &y);
getLcm(x, y);
printf("这两个正整数的最大公约数为:%d\n", gcd);
printf("这两个正整数的最小公倍数为:%d\n", lcm);
return 0;
}
```
方法二:不使用全局变量
```c
#include <stdio.h>
// 求最大公约数
int getGcd(int x, int y) {
int t;
if (x < y) {
t = x;
x = y;
y = t;
}
do {
t = x % y;
if (t != 0) {
x = y;
y = t;
t = x % y;
}
} while (t != 0);
return y;
}
// 求最小公倍数
int getLcm(int x, int y) {
int gcd = getGcd(x, y);
return x * y / gcd;
}
int main() {
int x, y, gcd, lcm;
printf("请输入两个正整数:");
scanf("%d,%d", &x, &y);
gcd = getGcd(x, y);
lcm = getLcm(x, y);
printf("这两个正整数的最大公约数为:%d\n", gcd);
printf("这两个正整数的最小公倍数为:%d\n", lcm);
return 0;
}
```
计算两个正整数的最小公倍数c语言
可以通过以下的代码来计算两个正整数的最小公倍数:
```c
#include <stdio.h>
int main() {
int num1, num2, max;
printf("请输入两个整数:\n");
scanf("%d %d", &num1, &num2);
max = (num1 > num2) ? num1 : num2;
while (1) {
if (max % num1 == 0 && max % num2 == 0) {
printf("两数的最小公倍数为:%d\n", max);
break;
}
max++;
}
return 0;
}
```
在程序中,我们首先获取两个整数,并找到两个数中最大的一个数。然后我们不断地增加最大数,并检查该数是否同时是两个输入数的倍数。如果是,那么该数就是这两个数的最小公倍数。如果不是,我们继续增加最大数,直到找到最小公倍数。