エラトステネスのふるいを使用して num までのすべての素数を見つけるためにこの Java プログラムを作成していますが、コンパイルしようとすると、長い var を配列インデックスとして使用できないと表示され、int var が必要ですその場所。しかし、私は大きな数で作業するので、int は使用できません。私に何ができる?
import java.util.*;
import java.lang.*;
public class t3{
public static void main(String[] args){
long num = 100;
//declaring list and filling it with numbers
ArrayList<Long> numlist = new ArrayList<Long>();
for(long x=2 ; x<num ; x++){
numlist.add(new Long(x));
}
//sieve or eratosthenes
for(long x=0 ; x<Math.sqrt(num) ; x++){
for(long y=x+1 ; y<numlist.size() ; y++){
if(numlist[y]%numlist[x] == 0){
numlist.remove(y);
}
}
}
//print list
for(Object item : numlist){
System.out.println((Long)item);
}
}
}