在这段代码中,当我在 main
方法中创建一个 Object,然后调用该对象方法: ff.twentyDivCount(i)
(运行时间为16010ms)时,它的运行速度远远快于使用这个注释: twentyDivCount(i)
(运行时间为59516ms)。当然,在不创建对象的情况下运行它时,我使方法是静态的,因此可以在 main 中调用它。
public class ProblemFive {
// Counts the number of numbers that the entry is evenly divisible by, as max is 20
int twentyDivCount(int a) { // Change to static int.... when using it directly
int count = 0;
for (int i = 1; i<21; i++) {
if (a % i == 0) {
count++;
}
}
return count;
}
public static void main(String[] args) {
long startT = System.currentTimeMillis();;
int start = 500000000;
int result = start;
ProblemFive ff = new ProblemFive();
for (int i = start; i > 0; i--) {
int temp = ff.twentyDivCount(i); // Faster way
// twentyDivCount(i) - slower
if (temp == 20) {
result = i;
System.out.println(result);
}
}
System.out.println(result);
long end = System.currentTimeMillis();;
System.out.println((end - startT) + " ms");
}
}
编辑: 到目前为止,似乎不同的机器产生不同的结果,但使用 JRE 1.8。* 是原始结果似乎一直被复制的地方。