我是初学者,帮我看看这个JAVA小程序,输出总有错…

题目是输出一个整数的质因子。我的做法是先求出该数的因子,再判断是否质数并输出我输入21,但输出却是72121大家帮我看看。谢谢了publicclassPrime{publ... 题目是输出一个整数的质因子。我的做法是先求出该数的因子,再判断是否质数并输出
我输入21,但输出却是7 21 21
大家帮我看看。
谢谢了
public class Prime {

public static void main(String[] args) {
System.out.println("输入一个整数:");
Scanner in = new Scanner(System.in);
int a = in.nextInt();
System.out.println("该数的质因子有:");
for(int n=1;n<=a;n++) {
if(a % n == 0){
for(int h =2;h<=Math.sqrt(n);h++){
if(n % h != 0)
System.out.print(n + " ");
}
}
}

}
}
展开
 我来答
Jseven_jy
2010-09-22 · TA获得超过8122个赞
知道大有可为答主
回答量:2499
采纳率:100%
帮助的人:1151万
展开全部
判断质数那里有点问题,给你改了下,代码如下,我测试过了,应该没问题,希望能帮到你~!

public class Prime {

public static void main(String[] args) {
System.out.println("输入一个整数:");
Scanner in = new Scanner(System.in);
int a = in.nextInt();
System.out.println("该数的质因子有:");
for (int n = 2; n <= a / 2; n++) {
if (a % n == 0) {
int h;
for ( h = 2; h <= n / 2; h++) {
if (n % h == 0)
break;
}
if(h>n/2){
System.out.print(n + " ");
}
}
}

}
}
419469557
2010-09-22 · TA获得超过146个赞
知道答主
回答量:117
采纳率:0%
帮助的人:59.5万
展开全部
不会
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
ghogel
2010-09-22 · TA获得超过1388个赞
知道小有建树答主
回答量:1119
采纳率:33%
帮助的人:477万
展开全部
十一级的修改的非常好.

我说一说你的为什么会输出7,21,21

在你的第二个for里,

n是7的时候, h =2;h<=Math.sqrt(n);h只能取2,你下面 if(n % h != 0) 所以只输出一次”7”
下一次循环,n就21了, h =2;h<=Math.sqrt(n);h就可以取2.3.4三个值,有两个值符合 if(n % h != 0),所以输出两个”21”.

归根到底,你的算法不对,看一下十一级Jseven_jy的算法吧.
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
匿名用户
2010-09-22
展开全部
import java.util.Scanner;
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(2)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式