码迷,mamicode.com
首页 > 其他好文 > 详细

最大公约数与最小公倍数

时间:2018-08-21 19:39:30      阅读:151      评论:0      收藏:0      [点我收藏+]

标签:相减   等于   tip   mes   tween   stdio.h   gre   mon   include   

1. 最小公倍数

a,b的最小公倍数等于 a*b/最大公约数

2. 最大公约数

2.1 辗转相除法
① a%b得到余数c
② 若c=0,则c即是最大公约数
③ 若c≠0,则 a=b,b=c,再返回①
注意:这里假设a,b都是正数,因此无需判断a,b的大小,因为当a<b时,第一轮循环后a,b就会互换。

#include<stdio.h>
using namespace std;
int main()
{
    int a=0,b=0,c=0;
    while(scanf("%d %d",&a,&b))
    {
        int m=a,n=b;
        while(n!=0)
        {
            c=m%n;
            m=n;
            n=c;
        }
        printf("The Greatest common divisor between %d and %d is:%d\n",a,b,m);
        printf("The least common multiple between %d and %d is:%d\n",a,b,a*b/m);
    }
}

2.2 更相减损法
① 若a>b,则a=a-b;
② 若a<b,则b=b-a;
③ 若a=b,则a or b就是最大公约数

#include<stdio.h>
using namespace std;
int main()
{
    int a=0,b=0;
    while(scanf("%d %d",&a,&b))
    {
        int m=a,n=b;
        while(m!=n)
        {
            if(m>n)
                m=m-n;
            else
                n=n-m;
        }
        printf("The Greatest common divisor between %d and %d is:%d\n",a,b,m);
        printf("The least common multiple between %d and %d is:%d\n",a,b,a*b/m);
    }
}

以上

最大公约数与最小公倍数

标签:相减   等于   tip   mes   tween   stdio.h   gre   mon   include   

原文地址:https://www.cnblogs.com/qiulinzhang/p/9513368.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!