千家信息网

PHP递归函数算法和应用

发表于:2025-02-22 作者:千家信息网编辑
千家信息网最后更新 2025年02月22日,这篇文章主要介绍"PHP递归函数算法和应用",在日常操作中,相信很多人在PHP递归函数算法和应用问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答"PHP递归函数算法和应用"
千家信息网最后更新 2025年02月22日PHP递归函数算法和应用

这篇文章主要介绍"PHP递归函数算法和应用",在日常操作中,相信很多人在PHP递归函数算法和应用问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答"PHP递归函数算法和应用"的疑惑有所帮助!接下来,请跟着小编一起来学习吧!

1、调用子程序的含义:

当主程序执行到调用子程序A语句时,系统保存一些必要的现场数据,然后执行类似于BASIC语言的GOTO语句,跳转到子程序A(为了说得简单些,我这里忽略了参数传递这个过程)。当子程序A执行到调用子程序B语句时,系统作法如上,跳转到子程序B。子程序B执行完所有语句后,跳转回子程序A调用子程序B语句的下一条语句(我这又忽略了返回值处理)子程序A执行完后,跳转回主程序调用子程序A语句的下一条语句,主程序执行到结束。做个比较:我在吃饭(执行主程序)吃到一半时,某人叫我(执行子程序A),话正说到一半,电话又响了起来(执行子程序B),我只要先接完电话,再和某人把话说完,***把饭吃完(我这饭吃得也够累的了J)。

2、认识递归函数

我们在高中时都学过数学归纳法,PHP递归算法例如:

求 n!我们可以把n!这么定义也就是说要求3!,我们必须先求出2!,要求2!,必须先求1!,要求1!,就必须先求0!,而0!=1,所以1!=0!*1=1,再进而求2!,3!。分别用函数表示,我们可以观察到,除计算0!子程序外,其他的子程序基本相似,我们可以设计这么一个子程序:

int factorial(int i){  int res;  res=factorial(I-1)*i;  return res;  }

那么当执行主程序语句s=factorial(3)时,就会执行factorial(3),但在执行factorial(3),又会调用 factorial(2),这时大家要注意,factorial(3)和factorial(2)虽然是同一个代码段,但在内存中它的数据区是两份!而执行factorial(2)时又会调用factorial(1),执行factorial(1)时又会调用factorial(0),每调用一次 factorial函数,它就会在内存中新增一个数据区,那么这些复制了多份的函数大家可以把它看成是多个不同名的函数来理解;但我们这个函数有点问题,在执行factorial(0)时,它又会调用factorial(-1)。。。造成死循环,也就是说,在factorial函数中,我们要在适当的时候保证不再调用该函数,也就是不执行res=factorial(I-1)*i;这条调用语句。所以函数要改成:

int factorial(int i){  int res;  if (I>0) res=factorial(I-1)*i; else res=1;  return res;  }

3、如何考虑用PHP递归算法来解决问题

例:求s=1+2+3+4+5+6+……+n本来这个问题我们过去常用循环累加的方法。而这里如要用递归的方法,必须考虑两点:
1) 能否把问题转化成递归形式的描述;
2) 是否有递归结束的边界条件。

显然递归的两个条件都有了:

1) s(n) =s(n-1)+n  2) s(1)=1

所以源程序为:

int progression(int n){  int res;  if (n=1 )res=1 else res=progression(n-1)+n;  return res;  }

4、递归的应用

中序遍历二叉树

void inorder (BinTree T){  if (T){  inorder(T->lchild);  printf("%c",T->data);  inorder(T->rchild);  }  }

到此,关于"PHP递归函数算法和应用"的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注网站,小编会继续努力为大家带来更多实用的文章!

子程序 函数 递归 语句 算法 应用 主程序 问题 学习 也就是 数据 方法 也就是说 内存 更多 条件 电话 系统 帮助 循环 数据库的安全要保护哪些东西 数据库安全各自的含义是什么 生产安全数据库录入 数据库的安全性及管理 数据库安全策略包含哪些 海淀数据库安全审计系统 建立农村房屋安全信息数据库 易用的数据库客户端支持安全管理 连接数据库失败ssl安全错误 数据库的锁怎样保障安全 信息网络技术专业怎么样 山西it软件开发的用途和特点 不同数据库两张表数据同步 幻灵游侠数据库修改技术 计算机网络技术算什么 大专网络技术基础书籍 软件开发企业成本核算摘要 戴尔服务器设置radio 如何将安装包放到服务器让人下载 我的世界服务器连接不到怎么办 菲尼克斯电气软件开发工程师 宽度服务器无响应 网络安全法同步同步同步 帝国网络安全手抄报 数据库管理服务器型号和价格 网络安全网课报名 科技互联网行业排名 成都任我行网络技术 想学网络技术加盟排行前十 免费领取数据库 商品规格数据库设计 网络安全知识进入社区 自研软件开发平台 计算机类国家网络安全学院就业 apex无法获取服务器列表 传感器网络技术原理及应用 万德数据库查A股开户数 游乐旅途成都网络技术有限公司 计算机与网络技术接口是什么 鄂州天气预报软件开发
0