C# 递归

目录

一、什么是递归

二、递归的特点

三、递归的简单使用

        1、阶乘

        2、斐波拉西数列


一、什么是递归

        一个方法既可以调用其他方法又可以调用自己,而当这个方法调用自己时,我们就叫它递归。

二、递归的特点

        1、递归方法一直会调用自己直到某些条件满足,因此递归方法要有一个明确的递归结束条件,也就是递归出口。

        2、递归算法解题通常显得很简洁,但递归算法解题的运行效率较低。

        3、在递归调用的过程当中系统为每一层的返回点、局部量等开辟了栈来存储。递归次数过多容易造成栈溢出等。

三、递归的简单使用

 1、阶乘

 public static int Factorial(int i)
{
  if (i == 0)
  {
    return 1;
  }
  else
  {
    return i * Factorial(i - 1);
  }
}

 2、斐波拉西数列

        斐波那契数列是指这样一个数列:0, 1, 1, 2, 3, 5, 8, 13, 21, 34, 55, 89, 144……也就是第N(N > 2)个数等于第(N - 1)个数和(N - 2)个数的和。F[n]=F[n-1]+F[n-2](n>=2,F[0]=0,F[1]=1)。

public static int Fibonacci(int i)
{
  if (i == 0 || i == 1)
  {
    return i;
  }
  else
  {
    return Fibonacci(i - 1) + Fibonacci(i - 2);
  }
}
  • 1
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值