当前位置: 首页 > news >正文

函数的递归调用

1、什么是函数的递归调用?

其实说白了就是在函数的内部再调用函数自己本身

function fun(){fun()
}

2、用递归解决问题的条件

(1)一个问题是可以分解成子问题,子问题的解决办法与最原始的问题解决方法相同

(2)在问题分解过程中必须要有明确的结束条件

3、递归过程

(1)递去:从上到下分解问题

(2)归来:从结束条件的位置开始进行回溯,最终得到问题的解

示例:利用递归计算一个数的阶乘

function fun(num){if(n == 1){return 1;}else{return n * fun(num - 1);]
}

4、递归的应用场景

(1)深拷贝

function fun(oldObj){//定义变量用于拷贝oldObj   let newObj = Array.isArray(oldObj)?[]:{}//遍历oldObj的属性for(let item in oldObj){//oldObj[item]是属性item的值let temp = oldObj[item];//若item的属性值存在并且是一个对象,则递归访问该对象if(temp && typeof(temp) === 'object'){newObj[item] = fun(temp);}else{//若item的属性值不是一个对象,则直接拷贝newObj[item] = temp;}}//将得到新的对象返回return newObj;
}let person = {name:'小王',age:22,cat:{name:'多多',age:3},friend:['小张','小李']
}fun(person);

 

(2)遍历树形菜单:将数组转换成多级菜单

(3)递归实现表格的多级表头

http://www.lryc.cn/news/152675.html

相关文章:

  • 李宏毅机器学习笔记:RNN循环神经网络
  • 基于JavaWeb和mysql实现校园订餐前后台管理系统(源码+数据库)
  • CNN 01(CNN简介)
  • AI大模型的使用-让AI帮你写单元测试
  • vscode调教配置:快捷修复和格式化代码
  • pear admin 后端启动
  • C++:输出系统时间(及报错处理)
  • 使用Windbg动态调试排查软件启动不了的问题
  • Swift 技术 视频播放器滚动条(源码)
  • PixelSNAIL论文代码学习(2)——门控残差网络的实现
  • WebGPU学习(9)---使用Pipeline Overridable Constants
  • javaweb入门版学生信息管理系统-增删改查+JSP+Jstl+El
  • 云原生Kubernetes:K8S概述
  • nmap的使用
  • Python爬虫-某网酒店数据
  • 了解atoi和offsetof
  • 命令行编译VS工程
  • Linux防火墙命令
  • 大数据平台数据脱敏是什么意思?有哪些方案?
  • 前后端分离不存在会话,sessionid不一致问题
  • Python 3+ 安装及pip配置
  • StarRocks入门到熟练
  • Zabbix Api监控项值推送:zabbix_sender
  • Shell脚本开发:printf和test命令的实际应用
  • React笔记(三)类组件(1)
  • Hugging Face实战-系列教程4:padding与attention_mask
  • 睿趣科技:抖音开网店卖玩具怎么样
  • 简易虚拟培训系统-UI控件的应用4
  • #include <graphics.h> #include <conio.h> #include<stdlib.h>无法打开源文件解决方案
  • 【C语言】数据结构的基本概念与评价算法的指标