尾递归

什么是尾递归呢?(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));
    }

}
相关文章
相关标签/搜索