最大公约数一定<=min(a,b);
最小公倍数一定>=max(a,b);
1.辗转相除法
int my_gcd(int x, int y)
{
int r;
while (r = x % y) //x / y == q...r
{
x = y;
y = r;
}
return r;
}
2.辗转相减法
#include<stdio.h>
int my_gcd(int a, int b)
{
while (a != b)
{
if (a > b)
a -= b;
else
b -= a;
}
return a;
}
int main()
{
int a, b;
scanf("%d %d", &a, &b);
printf("%d", my_gcd(a, b));
return 0;
}
3.穷举法
#include<stdio.h>
int my_gcd(int x, int y)
{
int i, m = x < y ? x : y;
for (i = m; ; i--)
{
if (x % i == 0 && y % i == 0)
break;
}
return i;
}
int main()
{
int a, b;
scanf("%d %d", &a, &b);
printf("%d", my_gcd(a, b));
return 0;
}
4.递归法
#include<stdio.h>
int my_gcd(int x, int y)
{
if (y == 0)
return x;
else
return my_gcd(y, x % y); //x / y == q...r
}
int main()
{
int a, b;
scanf("%d %d", &a, &b);
printf("%d", my_gcd(a, b));
return 0;
}