首页
学习
活动
专区
圈层
工具
发布

LCM计算
EN

Stack Overflow用户
提问于 2014-03-31 21:00:54
回答 1查看 671关注 0票数 0

我为spoj中给出的计算LCM的问题编写了代码。我计算了两个数的gcd,用gcd除以两个数的乘法,给出了两个数的lcm,但它显示了错误的答案。

问题是在http://www.spoj.com/problems/WPC5I/

代码语言:javascript
复制
import java.math.BigInteger;
import java.util.Scanner;

class Lcm1 {
    public static void main(String args[]) throws Throwable {
        try {
            Scanner s = new Scanner(System.in);
            int siz = s.nextInt();
            for(int i = 0; i< siz; i++) {
                BigInteger a = s.nextBigInteger(), b = s.nextBigInteger();
                System.out.println((a.multiply(b)).divide(a.gcd(b)));
            }
        }
        catch(Exception e){}
    }
}
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2014-04-11 21:29:11

您的逻辑部分是wrong.Basically,您只是计算给定数字的lcm,但是用户要求找到最少k满足给定的condition.but,而不是k。请尝试使用n=340和m=230实际ans是1564,但是您的代码给出了7820。

注: lcm并不总是满足问题中给定条件的最小k。

提示:素数分解m,n,并尝试得到更多情况下的ans...try,您就会得到它。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/22772078

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档