在编程啦网站上做的一个题,总是说结果错误,实在找不出是哪错了了,求指教······
题目是这样的
超级最小公倍数
时间限制:8000 ms | 内存限制:16384 KB
描述
给2个正整数a,b(1<=a,b<=10100),求a和b的最小公倍数。
输入
输入包含多组数据,每组数据一行,包含两个正整数a和b,中间以一个空格隔开。输入以0 0结束。
输出
每组数据输出一行,为a,b的最小公倍数。
样例输入
123 321
123456789 987654321
0 0
样例输出
13161
13548070123626141
我的程序是
import java.util.Scanner;
public class Main{
public static void main(String[] args){
Scanner scan=new Scanner(System.in);
long a=scan.nextInt();
long b=scan.nextInt();
while(a!=0&&b!=0){
long g=commonDivisor(a, b);
long a1=a/g;
long a2=b/g;
System.out.println(a1*g*a2);
a=scan.nextInt();
b=scan.nextInt();
}
}
public static long commonDivisor(long M, long N){
if(N==0)
return M;
else
return commonDivisor(N,M%N);
}
}
------解决方案--------------------代码是对的,可是LZ你没验证输入的合法性,可能是字母,也可能范围不是int的
------解决方案--------------------这个题目出的有点问题:请注意题目中样例
题目的描述
给2个正整数a,b(1<=a,b<=10100),求a和b的最小公倍数。
题目的样例:
样例输入
123 321
123456789 987654321
0 0
样例输出
13161
13548070123626141
很明显有矛盾啊,他说q,b的范围在 1~10100,但是例子不是哦.我觉得这个题目的意思应该是考大数吧?