排除任何特殊的循环中断(中断、更改计数器等),公式如下:
迭代次数 = (end - start+incr)/incr,其中关系运算符为 >= 或 <=
如果关系运算符是 < 或 >,则迭代次数 = (end - start+incr-1)/incr
这可以测试如下
/*
* Baring any special disruption of the loop (breaks, altering counter, etc), the formula is as follows:
iterations = (|start-end|+|incr|)/|incr|, where relational operator is >= or <=
- if relational operator is < or >, then iterations = ((|start-end|+|incr|-1)/|incr|
* @author rahul.arora, WJS
*/
import java.util.Random;
public class LoopIterationCalcTester {
public static void main(String[] args) {
for (int x = 0; x < 100; x++) {
Random r = new Random();
for (int k = 0; k < 10000; k++) {
int count = 0;
int start = r.nextInt(20)+1;
int end = r.nextInt(1000) + 20;
int incr = r.nextInt(50)+1;
for (int i = start; i < end; i += incr) {
count++;
}
int calc = (end - start-1+incr)/incr;
if (calc != count) {
System.out.println("Oops");
}
}
for (int k = 0; k < 10000; k++) {
int count = 0;
int start = r.nextInt(20)+1;
int end = r.nextInt(1000) + 20;
int incr = r.nextInt(50)+1;
for (int i = start; i <= end; i += incr) {
count++;
}
int calc = (end - start+incr)/incr;
if (calc != count) {
System.out.println("Oops");
}
}
for (int k = 0; k < 10000; k++) {
int count = 0;
int start = r.nextInt(20)+1;
int end = r.nextInt(1000) + 20;
int incr = r.nextInt(50)+1;
for (int i = end; i >= start; i -= incr) {
count++;
}
int calc = (end - start+incr)/incr;
if (calc != count) {
System.out.println("Oops");
}
}
for (int k = 0; k < 10000; k++) {
int count = 0;
int start = r.nextInt(20)+1;
int end = r.nextInt(1000) + 20;
int incr = r.nextInt(50)+1;
for (int i = end; i > start; i -= incr) {
count++;
}
int calc = (end - start-1+incr)/incr;
if (calc != count) {
System.out.println("Oops");
}
}
}
}
}