上一章已经说过利用数学思想来解决程序算法问题,实际上就是找规律。这在我们上学时经常遇到,比如给出一段数字,求某一个位置该填写什么数,只要找到规律那就迎刃而解。好了,废话不多说,再来看看案例分析。
public static int oneMethod(int index) { int sum = 0; if (index <= 0) { return 0; } // 循环区间累加 for (int i = 1; i <= index; i++) { sum += i; } return sum; }
可能还有的人会用递归算法来解决。如:
public static int twoMethod(int index) { if (index <= 0) { return 0; } return twoMethod(index - 1) + index; }
上面两种方法虽然都解决了问题,但是我认为这不是最好的解法。当index很大的时候,程序肯定吃不消的。而这样的数列甚至不用思考,完全是初中就学过的等差数列。对于1+2+3+4+5+6+……+100数列,都满足于(首项+末项)*项数/2,也就是n(n+1)*项数。不用循环也不用递归,一个公式就能解决问题了。
数学思想:
public static int threeMethod(int index) { if (index <= 0) { return 0; } return index * (index + 1) / 2; }
所以最终的解法要用三目运算判断返回的结果。如:
public static int calcRangeResult(int index) { if (index <= 0) { return 0; } return index % 2 == 0 ? calcRangeResult(index - 1) - index : calcRangeResult(index - 1) + index; }
是不是 so easy呀。