最小公倍数

    xiaoxiao2023-12-04  177

    题意

    求1-20的最小公倍数。

    求两个数a,b的最小公倍数嘛,先取出其中较大的那个比如a,然后再用ka去试探能否被较小那个数整除,其中,k是从1开始的自然数 ka<a*b。

    另外一种比较好的方法,以n取10为例

    2,3,4,5,6,7,8,9,10 (1没有什么意义,忽略掉了)

    将这些数字分解质因数:

    2, 3, 22, 5, 23, 7, 222, 33, 25

    这些质数分别是2, 3, 5, 7

    最终答案可以表示为:

    2^a * 3^b * 5^c * 7^d (其中,x^y表示x的y次方)

    其中的英文字母表示在上面分解质因数时所得到的表达式中质因数在同一个表达式中出现的次数的最大值。

    质因数2出现次数最多是在8=222中,其出现了3次,所以a为3。

    同理可得到:2^3 * 3^2 * 5^1 * 7^1 = 2520。

    #include<iostream> #include<algorithm> using namespace std; int lcm(int a ,int b) { int big=max(a,b); int small=min(a,b); int max=a*b; for(int i=big; i<max; i+=big) { if(i%small==0) return i; } return max; } int main() { int sum,a=1,b=2; while(b!=20) { sum=lcm(a,b); a=sum; b++; } cout<<sum<<endl; return 0; }

    题目比较简单,但可以扩展,进行比较会有其他收获

    最新回复(0)