24_函数_递归

复制代码
package com.dawang.scala.函数式编程_05

/**
  * @author gaocun
  * @create 2021-10-20 2:17 PM */
object 递归_07 {
  def main(args: Array[String]): Unit = {
    //for循环求阶乘
    def forJc(index: Int): Int = {
      var result = 1
      for (i <- 1 to index) {
        result *= i
      }
      result
    }

    println("forJc:" + forJc(5)) // 5*4*3*2*1

    //递归 f(x-1)f(x)
    def recuFun(index: Int): Int = {
      if (index == 1) 1
      else recuFun(index - 1) * index
    }

    println("recuFun:" + recuFun(5)) // 5*4*3*2*1


  }
}
复制代码

 

posted @   学而不思则罔!  阅读(20)  评论(0编辑  收藏  举报
编辑推荐:
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
阅读排行:
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 地球OL攻略 —— 某应届生求职总结
· 提示词工程——AI应用必不可少的技术
· 字符编码:从基础到乱码解决
· SpringCloud带你走进微服务的世界
点击右上角即可分享
微信分享提示