Scala递归函数

/**
 * 递归函数:在函数再次内部调用自己
 * 解决可以被分解为类似子问题的问题
 * 组成:
 * 1.基本情况。最小问题的答案
 * 2.递归情况。调用自己去解决子问题
*/
object TestFucRecursive {
//  def fn():Unit={
//    println("fn...")
//    fn()
//  }
//  def sum(n:Int):Int={
//    var s=0
//    for(i<-1 to n){
//      s+=1
//    }
//    s
//  }
//定义一个递归函数,求1-n的和
//  def sum(n:Int):Int ={
//    println(n)
//    //1.基本情况:最小问题,直接给答案,阻止死循环
//    if(n==1){
//      1
//    }
//    else {
//      //2.递归情况:再次调用自己去解决子情况
//      return n+sum(n-1)
//    }
//  }
  //定义一个函数,求1*2*3*4*...*n
  def mul(n: Int): Int = {
    if (n == 0) {
      1
    } else {
    mul(n - 1) * n
    }
  }
  def main(args: Array[String]): Unit = {
    var s = mul(5)//5*4*3*2*1 = 120
    println(s)
  }
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值