java 打印1到100之间的所有质数
程序员文章站
2024-03-14 19:46:17
...
质数,即只能被1和它本书整除的数,比如7就不是,因为7只能被1和7整除,其他的2,3,4,5,6都不可以。还有一点,除数只需 从1到它本身即可,比如8,检查一下8是否能被2,3,4,5,6,7整除即可。
public class zhishu {
public static void main (String[] args){
for (int i = 2 ; i <= 100 ; i++ ) {
int count = 0;
for (int j = 2 ; j < i ;j++ ) {
if ( i % j == 0 ){
break;
}
count++;
}
if (count != 0){
System.out.println(i);
}
}
}
}
上边这一段代码是正确的,下面的是错误的
public class zhishu {
public static void main (String[] args){
int count = 0;
for (int i = 2 ; i <= 100 ; i++ ) {
for (int j = 2 ; j < i ;j++ ) {
if ( i % j == 0 ){
break;
}
count++;
}
if (count != 0){
System.out.println(i);
}
}
}
}
下面这一段代码,由于计数器count在双重for循环的外面,所以每次当里面的for循环结束之后,count不会被重新赋值,二是延续之前的count值,所以会导致下面的count != 0 这个判断会失灵。要注意。
当然,定义一个boolean也是一样的,先令其的值为true。然后再在最后输出的时候,判断一下。将质数输出。当然在每次内部的for循环结束之后,一定要将boolean重新赋值。令其回到初始值true。否则会失灵
下一篇: bzoj 2721(线性筛)(约数个数)