数据结构与算法之--最大公约数最小公倍数

Posted zeromz

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了数据结构与算法之--最大公约数最小公倍数相关的知识,希望对你有一定的参考价值。

1、两数求最小公倍数:思路是,两个数,他们分别约去了最大公约数,剩下的两个数应该是互质的,它们的乘积就是这两个数的最小公倍数。

package com.lfy;

import java.util.Scanner;

/**
 * 
 * @author lfy
 * @since  2018/07/03
 * @version 1.0
 */
public class LeastCommonMultiple {

    public static void main(String[] args) {
        @SuppressWarnings("resource")
        Scanner input=new Scanner(System.in);
        int num1=input.nextInt();
        int num2=input.nextInt();
        //求两个数的最小公倍数
        System.out.println(get_LeastCommonMultiple(num1,num2));
    }

    //最小公倍数
    private static int get_LeastCommonMultiple(int num1, int num2) {
        
        return num1*num2/get_GreatestCommonDivisor(num1,num2);
    }

    //最大公约数
    private static int get_GreatestCommonDivisor(int num1, int num2) {
        int res=0;
        if(num1<num2) {
            num1=num1+num2;
            num2=num1-num2;
            num1=num1-num2;
        }
        if(num1%num2==0) {
            res=num2;
        }
        while(num1%num2>0) {
            num1=num1%num2;
            if(num2>num1) {
                num1=num1+num2;
                num2=num1-num2;
                num1=num1-num2;
            }
            if(num1%num2==0) {
                res=num2;
            }
        }
        return res;
    }

}

2、求两数的最大公约数,主要的出发思想是基于两数的最大公约数性质出发的:

    性质1 如果a>b,则a和b与a-b和b的最大公约数相同,即Gcd(a, b) = Gcd(a-b, b)
    性质2 如果b>a,则a和b与a和b-a的最大公约数相同,即Gcd(a, b) = Gcd(a, b-a)
    性质3 如果a=b,则a和b的最大公约数与a值和b值相同,即Gcd(a, b) = a = b

    



以上是关于数据结构与算法之--最大公约数最小公倍数的主要内容,如果未能解决你的问题,请参考以下文章

算法与数据结构最大公约数和最小公倍数的Java程序

贪心算法之随机三个数的最小公倍数

比给定值最小的最大元素的 STL 算法

数据结构与算法之深入解析“分割数组的最大值”的求解思路与算法示例

经典排序之选择排序

排序算法之选择排序