什么是尾递归呢?(tail recursion), 顾名思议,就是一种“不同的”递归,说到它的不同,就得先说说通常的递归。对于通常的递归,好比下面的求阶乘,教科书上会告诉咱们,若是这个函数调用的深度太深,很容易会有爆栈的危险。java
尾递归就能够大大缩小了栈的深度,能够出栈浏览器
例题:切面条 ---蓝桥杯函数
标题:切面条spa
一根高筋拉面,中间切一刀,能够获得2根面条。code
若是先对折1次,中间切一刀,能够获得3根面条。blog
若是连续对折2次,中间切一刀,能够获得5根面条。递归
那么,连续对折10次,中间切一刀,会获得多少面条呢?io
答案是个整数,请经过浏览器提交答案。不要填写任何多余的内容。class
package demo2; import java.math.BigInteger; import java.util.*; public class Main8 { public static int f(int n,int r){ if(n==0) return r; return f(n-1,2*r-1); } public static void main(String[] args) { Scanner sc = new Scanner(System.in); int n = 10; System.out.println(f(10,2)); } }