转载自:http://blog.sina.com.cn/s/blog_622e77cc0100n5lm.html
1、根据质数的定义求
质数定义:只能被1或者自身整除的自然数(不包括1),称为质数。
利用它的定义可以循环判断该数除以比它小的每个自然数(大于1),如果有能被它整除的,则它就不是质数。
对应代码是:
void printPrime(int n){//判断n是否是质数
boolean isPrime=true;//是否是质数的标志
for(int i=n-1;i>1;i—){//n除以每个比n小比1大的自然数
if(n%i==0){//如果有能被整除的,则不是质数
isPrime=false;
}
}
if(isPrime){//如果是质数,则打印出来
System.out.print(n+" ");
primeNumber++;//记录质数的个数
if(primeNumber%10==0)//输出10个质数后换行
System.out.println();
}
}
2、利用一个定理——如果一个数是合数,那么它的最小质因数肯定小于等于他的平方根。例如:50,最小质因数是2,2<50的开根号
再比如:15,最小质因数是3,3<15的开根号
合数是与质数相对应的自然数。一个大于1的自然数如果它不是合数,则它是质数。
上面的定理是说,如果一个数能被它的最小质因数整除的话,那它肯定是合数,即不是质数。所以判断一个数是否是质数,只需判断它是否能被小于它开跟后后的所有数整除,这样做的运算就会少了很多,因此效率也高了很多。
对应代码是:
void printPrime(int n){//判断n是否是质数
boolean isPrime=true;//是否是质数的标志
int s=(int)Math.sqrt(n);//对n开根号
for(int i=s;i>1;i—){//n除以每个比n开根号小比1大的自然数
if(n%i==0){//如果有能被整除的,则不是质数
isPrime=false;
}
}
if(isPrime){//如果是质数,则打印出来
System.out.print(n+" ");
primeNumber++;//记录质数的个数
if(primeNumber%10==0)//输出10个质数后换行
System.out.println();