nynu-ycg6
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);所以此题又转化为求多个数的最大公约数的问题,利用辗转相除最后求得结果。

分类:

技术点:

相关文章:

  • 2022-12-23
  • 2021-08-15
  • 2021-12-28
  • 2021-06-01
  • 2021-12-22
  • 2022-12-23
  • 2022-12-23
  • 2021-10-31
猜你喜欢
  • 2022-12-23
  • 2021-04-12
  • 2021-11-03
  • 2021-09-27
  • 2022-01-22
  • 2022-12-23
  • 2022-12-23
相关资源
相似解决方案