java基础第二十九篇 递归方法

34 篇文章 0 订阅
30 篇文章 0 订阅

递归方法:一个方法体内调用它自身

方法递归包含了一种隐式的循环,它会重复执行某段代码,但这种重复执 行无须循环控制。

递归一定要向已知方向(设定结束条件)递归,否则这种递归就变成了无穷递归,类似于死循环。

 

例如求n以内的自然数的总和:

package recursionTest;

public class recursionTest {
    public static void main(String args[]){
        /**
         * 求100以内的自然数的总和
         *
         */

     
        recursionTest r=new recursionTest();

        int sum=r.getRecursionTest(100);

        System.out.println(sum);


       

    }


    public int getRecursionTest(int num){
        //设定的特殊条件
        if (num ==1){
         //满足其条件则停止,或输出特殊情况
            return 1;
        }else{
          //循环结构
            return num +getRecursionTest(num-1);
        } }





}

 

求n以内的自然数的阶乘:

package recursionTest;

public class recursionTest {
    public static void main(String args[]){
        /**
         * 求100以内的自然数的总和
         *
         */

   
        recursionTest r=new recursionTest();
  
        //阶乘
        int sumAll=r.getRecursionTest1(25);

        System.out.println(sumAll);

    }


 


   //求1到n之间的阶乘:n!
    public int getRecursionTest1(int n){
        if (n==1){
            return 1;
        }else {
            return n * getRecursionTest1(n-1);
        }
    }



}

练习题:

package recursionTest;

public class recursionTest1 {
    public static void main(String args[]){
        recursionTest1 r=new recursionTest1();

        int ten=r.getSum(10);

        System.out.println(ten);

        int two=r.Sum(9);

        System.out.println(two);

    }

    /**
     *
     * 已知一个数列:f(20) = 1,f(21) = 4,f(n+2) = 2*f(n+1)+f(n),
        其中n是大于0的整数,求f(10)的值。
     */

    public int getSum(int n){
        if(n==0) {
            return 1;
        }else if (n==1){
            return 4;
        }else {
            return  2*getSum(n-1)+getSum(n-2);
        }
    }

    /**
     * 斐波那契数列的第n个值
     * @param n
     * @return
     */
    public int Sum(int n){
        if (n==1||n==2){
            return 1;
        }else {
            return  Sum(n-2)+Sum(n-1);
        }

    }




}

 

 

 

参考来自尚硅谷

 

 

 

 

 

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

随风而行无疾而歌

看官,觉得不错,奖励一下呗

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值