题解 | #小乐乐与欧几里得#

小乐乐与欧几里得

http://www.nowcoder.com/practice/da13e0cf321e4df9acd0fdf0a433cbb0

import java.util.Scanner;

// 要清楚最大公约数和最小公倍数的算法
public class Main {
    public static void main(String[] args) {
        Scanner sc = new Scanner(System.in);

        // 输入正整数n和m
        long n = sc.nextInt();
        long m = sc.nextInt();
        // 两个数中的最小值
        long min = 0;
        // 两个数中的最大值
        long max = 0;
        // 最大公约数
        long div = 0;
        // 最小公倍数
        long dcm = 0;
        // 求最大公约数和最小公倍数
        // 最大公约数 // 辗转相除法欧几里德算法
        // 例子:10,6
        /**
         * 10 % 6 = 4
         * 6 % 4 = 2
         * 4 % 2 = 0
         * 所以结果为0
         */
        if (m > n) {
            max = m;
            min = n;
        } else {
            max = n;
            min = m;
        }
        // 计算最大公约数
        long num = 0;
        while (true) {
            num = max % min;
            if (num == 0) {
                div = min;
                break;
            }
            max = min;
            min = num;
        }
        // 最小公倍数
        // 只需要先求出最大公约数。用两个数的乘积除以最大公约数即可。
        dcm = m * n / div;
        System.out.println(dcm + div);
    }
}
全部评论

相关推荐

今天 15:12
门头沟学院 运营
点赞 评论 收藏
分享
这不纯纯作弊了吗😢😢😢
编程界菜鸡:信这个的这辈子有了,这智商你靠啥都没用
点赞 评论 收藏
分享
05-22 09:23
门头沟学院 Java
点赞 评论 收藏
分享
06-02 15:17
门头沟学院 Java
心爱的idea:怎么会呢 应该是打招呼有问题 问就说实习6个月全国可飞随时到岗
点赞 评论 收藏
分享
不愿透露姓名的神秘牛友
07-01 12:22
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务