首页 > 其他 > 详细

求多个数的最小公倍数的问题

时间:2015-07-20 19:20:04      阅读:233      评论:0      收藏:0      [点我收藏+]
Problem Description
求n个数的最小公倍数。
 
Input
输入包含多个测试实例,每个测试实例的开始是一个正整数n,然后是n个正整数。
 
Output
为每组测试数据输出它们的最小公倍数,每个测试实例的输出占一行。你可以假设最后的输出是一个32位的整数。
 
Sample Input
2 4 6 3 2 5 7
 
Sample Output
12 70
 
#include <stdio.h>
#include <stdlib.h>
typedef long unsigned lu;
lu gcd(lu a,lu b)
{
    int c;
    c=a%b;
    while(c)
    {
        a=b;
        b=c;
        c=a%b;
    }
    return b;
}
lu lcm(lu a,lu b)
{
    return a*b/gcd(a,b);
}
int main()
{
    lu t,n;
    while(scanf("%lu",&t)!=EOF)
    { lu re=1;
        while(t--)
        {
            scanf("%lu",&n);
             re=lcm(re,n);
        }
        printf("%lu\n",re);
    }
    return 0;
}

 

*最小公倍数与最大公约数的关系:[a1,a2,..,an]=M/(M/a1,M/a2,..,M/an),其中M为a1,a2,..,an的乘积,a1,a2,..,an为正整数。

例如:对于4,6,8,10,有[4,6,8,10]=120,而M=4*6*8*10=1920,M/(M/a1,M/a2,..,M/an) =1920/(6*8*10,4*8*10,4*6*10,4*6*8)=1920/16=120。

*多个数最大公约数的算法实现

    求多个数最小公倍数可以转化为求多个数的最大公约数。求多个数的最大公约数(a1,a2,..,an)的传统方法是多次求两个数的最大公约数,即

(1)       用辗转相除法[2]计算a1和a2的最大公约数(a1,a2)

(2)       用辗转相除法计算(a1,a2)和a3的最大公约数,求得(a1,a2,a3)

(3)       用辗转相除法计算(a1,a2,a3)和a4的最大公约数,求得(a1,a2,a3,a4)

(4)       依此重复,直到求得(a1,a2,..,an)

上述方法需要n-1次辗转相除运算。

做此题的关键所在是找出最小公倍数与最大公约数之间的关系,即是abc的最小公倍数=a*b*c/gcd(a,b,c);所以此题又转化为求多个数的最大公约数的问题,利用辗转相除最后求得结果。

求多个数的最小公倍数的问题

原文:http://www.cnblogs.com/nynu-ycg6/p/4662017.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!