输入两个正整数
m
和n
,求其最大公约数和最小公倍数。
求最小公倍数算法:
最小公倍数 = 两整数的乘积 ÷ 最大公约数
根据求最小公倍数的算法,可以看出如果已知最大公约数,就能很容易求出最小公倍数。而通过辗转相除法和相减法,可以求得最大公约数,下面分别进行介绍。
代码如下:
#include<stdio.h>
int main()
{int m,n;//定义两个整数scanf("%d %d",&m,&n);int max,min;int a,b;//找出较小值a,较大值ba=m<n?m:n;//若m<n成立,则输出m,若不成立,则输出nb=m>n?m:n;//若m>n成立,则输出m,若不成立,则输出nfor(int i=1;i<=a;i++)循环1到较小数范围内的数{if(a%i==0&&b%i==0)能被同时整除{max=i;最大公约数}}min=m*n/max;//最小公倍数printf("最大公约数是:%d\n最小公倍数是:%d", max, min);return 0;
}