博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
java可以递归多少次
阅读量:4068 次
发布时间:2019-05-25

本文共 642 字,大约阅读时间需要 2 分钟。

之前曾经尝试用递归的方法解决九宫格的问题,提示栈溢出。我就挺好奇java到底可以递归多少级,又和哪些因素有关呢?

今天很无聊的做了个测试。

我写了个方法

public void rec1num(int i)

{
System.out.println("This is "+i+"recursion");
rec1num(i+1);
}

然后调用。结果递归了5093次,报错了。(不一定每次都会递归这么多次,但大约是这个数值)

我想如果我增加一个数会怎么样?

再写一个两个数的。运行了3764次。

public void rec2num(int i1,int i2)

{
int i;
i=(i1+i2+i1+i2)/4;
System.out.println("This is "+i+"recursion");
rec2num(i1+1,i2+1);
}

我想我如果把递归中多加点东西会怎么样。来两个做无用功的for循环

public void rec2num2(int i1,int i2)

{
int i;
for(i=0;i<1000;i++)
i1++;
for(i=0;i<1000;i++)
i1--;
System.out.println("This is "+i1+"recursion");
rec2num2(i1+1,i2+1);
}

运行了3141次。

看来递归的调用次数和参数数量,递归函数的复杂程度都是相关的。不知道和机器是不是相关呢?晚上换个电脑搞一搞。

转载地址:http://oymji.baihongyu.com/

你可能感兴趣的文章
如何成为编程高手
查看>>
本科生的编程水平到底有多高
查看>>
备忘:java中的递归
查看>>
Solr及Spring-Data-Solr入门学习
查看>>
python_time模块
查看>>
python_configparser(解析ini)
查看>>
selenium学习资料
查看>>
<转>文档视图指针互获
查看>>
从mysql中 导出/导入表及数据
查看>>
HQL语句大全(转)
查看>>
几个常用的Javascript字符串处理函数 spilt(),join(),substring()和indexof()
查看>>
javascript传参字符串 与引号的嵌套调用
查看>>
swiper插件的的使用
查看>>
layui插件的使用
查看>>
JS牛客网编译环境的使用
查看>>
9、VUE面经
查看>>
关于进制转换的具体实现代码
查看>>
Golang 数据可视化利器 go-echarts ,实际使用
查看>>
mysql 跨机器查询,使用dblink
查看>>
mysql5.6.34 升级到mysql5.7.32
查看>>