辗转相除法求最大公约数和最小公倍数的代码c
时间: 2024-06-13 17:04:23 浏览: 3
以下是使用C语言实现辗转相除法求最大公约数和最小公倍数的代码:
```
#include <stdio.h>
int main() {
int m = 0;
int n = 0;
int temp = 0;
printf("请输入正整数m和n的值:\n");
scanf("%d %d", &m, &n);
int sum = m * n;
if (m < n) {
temp = m;
m = n;
n = temp;
}
while (1) {
if (m % n == 0) {
break;
}
m = n;
n = m % n;
}
printf("最大公约数为:%d\n", n);
printf("最小公倍数为:%d\n", sum/n);
return 0;
}
```
其中,`m`和`n`分别为输入的两个正整数,`temp`为临时变量,`sum`为两数之积,`if`语句用于判断`m`和`n`的大小,`while`循环用于进行辗转相除法求最大公约数,最后输出最大公约数和最小公倍数。
相关问题
C语言用辗转相除法求最大公约数和最小公倍数
最大公约数和最小公倍数可以通过辗转相除法来求解。
辗转相除法,也叫欧几里得算法,是求最大公约数的一种方法。其基本思想是:两个整数的最大公约数等于其中较小的那个数和两数相除余数的最大公约数。即,设两数为a、b(a>b),它们的最大公约数设为gcd(a,b),根据辗转相除法,有:
gcd(a,b) = gcd(b,a%b)
当a%b=0时,b即为所求的最大公约数。
最小公倍数是指两个或多个整数公有的倍数中最小的一个。可以通过最大公约数来求解。设两数为a、b(a>b),它们的最小公倍数设为lcm(a,b),则有:
lcm(a,b) = a * b / gcd(a,b)
下面是用C语言实现辗转相除法求最大公约数和最小公倍数的代码:
```c
#include <stdio.h>
// 辗转相除法求最大公约数
int gcd(int a, int b) {
if (b == 0) {
return a;
}
return gcd(b, a % b);
}
// 求最小公倍数
int lcm(int a, int b) {
return a * b / gcd(a, b);
}
int main() {
int a, b;
printf("请输入两个整数:");
scanf("%d%d", &a, &b);
printf("它们的最大公约数为:%d\n", gcd(a, b));
printf("它们的最小公倍数为:%d\n", lcm(a, b));
return 0;
}
```
c语言用辗转相除法求最大公约数和最小公倍数
好的,我知道你要问关于C语言用辗转相除法求最大公约数和最小公倍数的问题。辗转相除法,也称欧几里得算法,是求解两个整数的最大公约数的常用方法之一。其基本想法是用较小数除较大数,再用出现的余数去除除数,直到余数为零为止。而最小公倍数则可以通过先求最大公约数,然后通过两数之积除以最大公约数得到。以下是C语言代码实现:
```c
#include <stdio.h>
int main()
{
int a, b, x, y, t, gcd, lcm;
printf("Enter two integers:\n");
scanf("%d %d", &x, &y);
a = x;
b = y;
// 求最大公约数
while (b != 0)
{
t = b;
b = a % b;
a = t;
}
gcd = a;
// 求最小公倍数
lcm = x * y / gcd;
printf("Greatest common divisor of %d and %d is %d\n", x, y, gcd);
printf("Least common multiple of %d and %d is %d\n", x, y, lcm);
return 0;
}
```
其中,a和b是两个需要求最大公约数的整数,x和y是输入的两个整数,t用于交换变量的值,gcd和lcm分别存放最大公约数和最小公倍数的结果。
相关推荐
![pdf](https://img-home.csdnimg.cn/images/20210720083512.png)
![py](https://img-home.csdnimg.cn/images/20210720083646.png)
![pdf](https://img-home.csdnimg.cn/images/20210720083512.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)