【南大操作系统课】如何将任意递归程序写为非递归形式

C语言就是状态机

妙啊
BV12L4y1379V 16:57附近

递归形式的汉诺塔解法

在这里插入图片描述

非递归形式的汉诺塔解法

在这里插入图片描述

感想

所有递归程序都可以“就地”转为非递归,基本步骤为:

  1. 定义代表当前程序状态的frame,frame中包含PC(可以理解为调试的时候高亮的那行代码)
  2. 定义函数语句的行为(call,ret,goto等)
    call(f)相当于 push frame,frame.pc = f
    ret相当于pop frame
  3. 定义以frame为元素的stack
  4. 初始状态frame压栈
  5. 当栈中有frame时,根据pc的位置执行对应的操作,每次操作执行完,将pc指向下一条语句

如果遇到不同函数之间的调用,可以定义属于不同函数的frame或者添加case

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值