java的初级问题 输入两个1~1000数字,要求在一行中输入,用空格隔开 求这两个数字的最小公倍数

我的内容是这么写的:

import java.util.*;
import java.io.*;
public class Ti1 {
public static void main(String args[]){
int a=0,b=0;
ArrayList<String> a1=new ArrayList<String>();
Scanner sc=new Scanner(System.in);
while(true){
String s=sc.nextLine();
StringTokenizer t=new StringTokenizer(s," ");
while(t.hasMoreTokens()){
a=Integer.parseInt(t.nextToken());
b=Integer.parseInt(t.nextToken());
}
int i=0;
while(true){
i++;
if(i%a==0&&i%b==0)
break;
}
System.out.println(i);
}
}
}
不知道错在哪里 我提交之后说答案有错 请问哪里出错了 或者帮忙再写一个

import java.util.Scanner;

public class Four {

public static void main(String[] args) {
Scanner sca=new Scanner(System.in);
while(true){
System.out.println("输入两个1-1000之间的数,用空格隔开/或者输入退出标识poj");
String num=sca.nextLine();//输入数字 或者退出标志
num=num.toLowerCase();//将输入的字符串变成小写,当输入的是poj时程序结束
if(num.equals("poj")){
break;
}
String[] strs=num.split(" ");
//将输入的字符串切割,获得空格前后的数字
int a=Integer.parseInt(strs[0]);
int b=Integer.parseInt(strs[1]);
int i=0;
while(true){
i++;
if(i%a==0&&i%b==0){
break;
}
}
System.out.println(a+","+b+"的最小公倍数是:"+i);
}
}

}
温馨提示:答案为网友推荐,仅供参考
第1个回答  2011-01-24
1.你的break;语句只能跳出一层while(true)循环,你的最外层循环是死循环,方法没有结束,除非输入不正确用Exception退出方法.
2.按照格式输入,方法执行后的结果没错,不按格式输入时产生的Exception没有捕捉.不清楚你说的出错是什么意思,加上try,catch自己查吧
第2个回答  2011-01-24
我测试了下,没错,不知道你说的哪里有错?把错误信息贴出来,或写清楚。
第3个回答  2011-01-24
经测试,是正确的。也可以用公式:a+b/2(网上查的)不知道管不管用
相似回答