在编写素数和程序中,发现了以下的问题:
在编程的过程中:
- 关于比较范围的不牢固
- 各数据需要给初始化的值
- 对于使用isPrime来辅助程序运行的遗忘
在程序运行的过程中:
- 除数不能为0
出现Exception in thread “main” java.lang.ArithmeticException: / by zero - 控制台一直出现同一个数字
出现死循环
下面是代码:
import java.util.Scanner;
public class Main {
public static void main(String[] args) {
int n,m;
int i;
int cnt = 0;
int sum = 0;
//要注意的是,在循环中使用isPrime的时候,需要将isPrime进行重置
int isPrime = 1;
Scanner in = new Scanner(System.in);
n = in.nextInt();
m = in.nextInt();
//输入限制
while(n>m||n<=0||m>200) {
n = in.nextInt();
m = in.nextInt();
}
//第一个循环,让变成cnt=n-1
for(i=2;cnt<n-1;i++) {
isPrime=1;
for(int j=2;j<i;j++) {
if(i%j==0) {
isPrime=0;
break;
}
}
if(isPrime==1){
cnt=cnt+1;
}
}
//第二个循环,无须将i重置,使得cnt从n->m(将会循环到m)
for(;cnt>=n-1&&cnt<=m-1;i++) {
for(int j=2;j<i;j++) {
isPrime=1;
if(i%j==0) {
isPrime=0;
break;
}
}
if(isPrime==1){
cnt=cnt+1;
sum=sum+i;
}
}System.out.println(+sum);
}
}