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

C# 递归执行顺序

为了方便进一步理解递归,写了一个数字输出

class Program
{static void Main(string[] args){int number = 5;RecursiveDecrease(number);}static void RecursiveDecrease(int n){if (n > 0){Console.WriteLine("Before recursive call do : " + n);RecursiveDecrease(n - 1);Console.WriteLine("After recursive call  do : " + n);}}
}

输出结果:

Before recursive call do : 5
Before recursive call do : 4
Before recursive call do : 3
Before recursive call do : 2
Before recursive call do : 1
After recursive call  do : 1
After recursive call  do : 2
After recursive call  do : 3
After recursive call  do : 4
After recursive call  do : 5

class Program
{static void Main(string[] args){int number = 5;int[] ages ={1, 2, 3};RecursiveDecrease(number,ages);}static void RecursiveDecrease(int n,int[] age){if (n > 0){Console.WriteLine("Before recursive call do : " + n+ " array: "+string.Join(",",age));RecursiveDecrease(n - 1,age);Console.WriteLine("After recursive call one  do : " + n+ " array: "+string.Join(",",age));n=n+19;for (int i = 0; i < age.Length; i++){age[i]=age[i]+10;}Console.WriteLine("After recursive call  two do : " + n+ " array: "+string.Join(",",age));}}
}

输出结果:

Before recursive call do : 5 array: 1,2,3
Before recursive call do : 4 array: 1,2,3
Before recursive call do : 3 array: 1,2,3
Before recursive call do : 2 array: 1,2,3
Before recursive call do : 1 array: 1,2,3
After recursive call one  do : 1 array: 1,2,3
After recursive call  two do : 20 array: 11,12,13
After recursive call one  do : 2 array: 11,12,13
After recursive call  two do : 21 array: 21,22,23
After recursive call one  do : 3 array: 21,22,23
After recursive call  two do : 22 array: 31,32,33
After recursive call one  do : 4 array: 31,32,33
After recursive call  two do : 23 array: 41,42,43
After recursive call one  do : 5 array: 41,42,43
After recursive call  two do : 24 array: 51,52,53

具体使用方法如下:

  • 定义一个递归函数,入参数和返回类型。
  • 在函数体内,编写递归停止条件和递归调用的语句。
  • 在递归调用前后,可以编写其他需要执行的代码

总结:

    递归的执行顺序是先进后出的,每次递归调用都会暂停当前的执行,进入到新的函数调用中执行,直到满足退出条件时递归结束,然后返回到上一层递归调用,继续执行后续的代码。

  1. 先进后出的场景使用包括但不限于:
  • 栈数据结构:递归函数的调用栈是一种典型的先进后出的结构,可以利用栈的特性实现一些需要后进先出的操作。
  • 深度优先搜索(DFS):在树或图的遍历过程中,可以使用递归实现深度优先搜索,先探索当前节点的子节点,再回溯到父节点的其他未探索子节点。
  • 解决复杂问题:递归可以将复杂问题分解成简单的子问题,并通过先解决子问题再合并的方式得到最终解。例如,递归可以用于计算斐波那契数列、阶乘、二叉树的高度等。
  • 反转操作:递归可以实现字符串、列表、数组等的反转操作,先处理最后一个元素,再处理前面的元素,从而实现先进后出的效果。
http://www.lryc.cn/news/292013.html

相关文章:

  • go 实现暴力破解数独
  • go语言-字符串处理常用函数
  • DevOps落地笔记-05|非功能需求:如何有效关注非功能需求
  • vs 撤销本地 commit 并保留更改
  • 深度解读NVMe计算存储协议-1
  • CHS_06.2.3.4_2+用信号量实现进程互斥、同步、前驱关系
  • Web实战丨基于Django的简单网页计数器
  • mysql8安装基础操作(一)
  • MIT6.5830 实验0
  • 【简便方法和积累】pytest 单元测试框架中便捷安装插件和执行问题
  • Zabbix数据库分离与邮件报警
  • mybatisplus-多数据源配置
  • 微信小程序(二十八)网络请求数据进行列表渲染
  • ubuntu22.04 安装conda
  • W801学习笔记十:HLK-W801制作学习机/NES游戏机(总结)
  • 《HTML 简易速速上手小册》第6章:HTML 语义与结构(2024 最新版)
  • 分析HarmonyOS应用/服务的CPU活动性能
  • Linux:理解信号量以及内核中的三种通信方式
  • 【ArcGIS微课1000例】0100:ArcGIS for CAD软件下载与安装(附安装包)
  • Django模型(一)
  • 【ChatGPT】文本向量化与余弦相似度:揭开文本处理的神秘面纱(5)
  • 计算机中丢失mfc100u.dll怎么解决,详细解析mfc100u.dll丢失的解决方法
  • 代码随想录 Leetcode617.合并二叉树
  • 知识价值1-github站点域名
  • 【PyRestTest】进行Benchmarking测试
  • cocos creator 调用预设体Prefab中的方法(调用另一个节点的方法)
  • Spring 学习2 --基于xml管理Bean
  • Java数组遍历深度解析
  • 海洋鱼类检测7种YOLOV8NANO
  • Vue2组件注册:全局组件和局部组件