我是Java编程的新手,曾试图解决Project Euler的一些问题,但不知何故,第一个问题就被卡住了。。。
我试图找到从0到1000的一系列数字的3和5的倍数之和…
我的代码如下:
import java.util.ArrayList;
public class SumOfMultiplesOf3And5 {
public static void main(String[] args) {
int i = 0;
int sum = 0;
int n = 0;
int totalforthree =0;
int totalforfive = 0;
int totalforall =0;
ArrayList<Integer> multiples = new ArrayList<Integer>();
for (i = 0; i < 1000; i++){
if(i % 3 == 0){
multiples.add(i);
totalforthree += i;
}
else if(i % 5 == 0){
multiples.add(i);
totalforfive += i;
}
}
while (n < multiples.size()){
sum += multiples.get(i);
System.out.println(sum);
}
totalforall = totalforthree + totalforfive;
System.out.println("The sum is: " + totalforall);
}
}
我得到的错误如下:
Exception in thread "main" java.lang.IndexOutOfBoundsException: Index: 1000, Size: 467
at java.util.ArrayList.rangeCheck(Unknown Source)
at java.util.ArrayList.get(Unknown Source)
at SumOfMultiplesOf3And5.main(SumOfMultiplesOf3And5.java:25)
我该如何解决这个问题?尽管大小小于1000,但抛出异常的原因是什么?
如果这些问题太基本,我很抱歉,但我刚刚开始编程,所以我真的很感激能得到任何帮助!
提前非常感谢!:)
我认为错误就在这里:
while (n < multiples.size()){
sum += multiples.get(i);//Here
System.out.println(sum);
}
您检查n
是否小于大小,但在i
处得到的数字可能小于大小,也可能不小于大小。您可以将其更改为:
sum += multiples.get(n);