C#(一):递归

计算阶乘(请使用递归算法实现) 3! ==> 3 * 2 * 1

    private static int GetFactorial(int num)
    {
        /*
         3 * 3 - 1
         2 * 2 - 1
         1 return 1
         */
        if (num == 1) return 1;
        //方法内部又调用自身的过程
        //核心思想:将问题转移给范围缩小的子问题
        //适用性:在解决问题过程中,又遇到相同问题
        //优势:将复杂的问题简单化
        //缺点:性能较差
        return num* GetFactorial(num - 1);
    }

    //递:反复调用,将需要的内容“递”到最后一级
    //归:逐层返回,将结果“归”还给最开始
    //例如:查找某目录内的所有文件,一层一层文件夹内查找

     /*
     *编写一个函数,当参数为8时,结果为多少?(请使用递归实现)
     *1 - 2 + 3 - 4 + 5 - 6......
     */

private static int GetValue(int num)
    {
        if (num == 1) return 1;

        if (num % 2 == 0)
            return GetValue(num - 1) - num;
        else
            return GetValue(num - 1) + num;
    }

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值