递归累加时,出java.lang.StackOverflowError了,怎么办?

来源:百度知道 编辑:UC知道 时间:2024/05/24 20:33:41
public class test {
private long f(int n){
if(n ==1){
return 1;
}
return n+f(n-1) ;
}
public static void main(String args[]){
System.out.print(new test().f(10000));
}
}
主要目的是递归的1到10000的累加

这么递归下去肯定会栈溢出。
如果单纯的想要1-10000的累加至于这么麻烦么?

累加的效率问题:
目前有下面两种方法:
方法一:
long sum = 0;
for(int i = 0;i < value;i++)
{
sum += i;
}

方法二:
long sum = 0;
sum = (value + 1) * value / 2;

当value值等于10000,使用方法一,运行10次有4次会产生15毫秒左右耗时,使用方法二,运行10次无耗时产生。
当value值等于100000,使用方法一,运行10次有5次会产生15毫秒左右耗时,使用方法二,运行10次无耗时产生。
当value值等于1000000,使用方法一,运行10次有10次会产生31毫秒左右耗时,使用方法二,运行10次无耗时产生。
......
以此类推,方法一累加计数的效率和方法二相比,随着value值的级数递增,效率相应下降。

测试代码:
public class SimpleArithmetic
{
public static void main(String[] args)
{
SimpleArithmetic sa = new SimpleArithmetic();
long sum = 0;
long time = 0;
long curTime = System.currentTimeMillis();
System.out.println("curTime=" + curTime);

//sum = sa.getSumCycle(1000000);
sum = sa.getSumNotCycle(1000000);
System.out