在编写素数和程序中,发现了以下的问题:
在编程的过程中:
- 关于比较范围的不牢固
- 各数据需要给初始化的值
- 对于使用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-1for(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);}}