位置: 编程技术 - 正文

php实现递归的三种基本方式(递归 php)

编辑:rootadmin

推荐整理分享php实现递归的三种基本方式(递归 php),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:php递归实现1到100的和,php递归阶乘,php递归函数的例子,php递归函数的例子,php递归算法经典题目,php递归函数的例子,php递归函数详解,php递归函数详解,内容如对您有帮助,希望把文章链接给更多的朋友!

递归函数是我们常用到的一类函数,最基本的特点是函数自身调用自身,但必须在调用自身前有条件判断,否则无限无限调用下去。实现递归函数可以采取什么方式呢?本文列出了三种基本方式。理解其原来需要一定的基础知识水品,包括对全局变量,引用,静态变量的理解,也需对他们的作用范围有所理解。递归函数也是解决无限级分类的一个很好地技巧。如果对无限级分类感兴趣,请参照php利用递归函数实现无限级分类。我习惯套用通俗的话解释复杂的道理,您确实不明白请参见手册。

  利用引用做参数

  先不管引用做不做参数,必须先明白引用到底是什么?引用不过是指两个不同名的变量指向同一块存储地址。本来每个变量有各自的存储地址,赋值删除各行其道。现在可好,两个变量共享一块存储地址。 $a=&$b; 。实际上指的是 $a 不管不顾自己原来的存储地址,非要和 $b 共享一室了。因而任何对存储地址数值的改变都会影响两个值。  

  函数之间本来也是各行其是,即便是同名函数。递归函数是考虑将引用作为参数,成为一个桥梁,形成两个函数间的数据共享。虽然两个函数见貌似操作的是不同地址,但是实际上操作的是一块儿内存地址。

  上面的例子非常简答,以a<作为判断条件,条件成立,则把a赋给result[];将result的引用传入函数,会将每一次递归产生的a添加到结果数组result。因而本例生成的$result数组是 Array ( [0] => 1 [1] => 2 [2] => 3 [3] => 4 [4] => 5 [5] => 6 [6] => 7 [7] => 8 [8] => 9 ) 。

本例比较有意思的是echo a的值。相信很多人认为是吧,其实不然,是。为什么呢?因为函数还没执行echoa前就进行了下一次的函数递归。真正执行echo a是当a<条件不满足的时候,echo a,返回result,对于上一层而言,执行完递归函数,开始执行本层的echo $a,依次类推。

  利用全局变量

  利用全局变量完成递归函数,请确保你确实理解什么是全局变量。global在函数内申明变量不过是外部变量的同名引用。变量的作用范围仍然在本函数范围内。改变这些变量的值,外部同名变量的值自然也改变了。但一旦用了&,同名变量不再是同名引用。利用全局变量实现递归函数没必要理解到这么深的一层,还保持原有对全局变量的看法就可以顺理成章理解递归函数。

php实现递归的三种基本方式(递归 php)

  利用静态变量

  我们常常在类中见到static,今天我们把它利用到递归函数中。请记住static的作用:仅在第一次调用函数的时候对变量进行初始化,并且保留变量值。

  举个栗子:

  请问这一段代码的执行结果是多少?是么?必然不是。是。首先第一次调用test(),static对 $count 进行初始化,其后每一次执行完都会保留 $count 的值,不再进行初始化,相当于直接忽略了 static $count=0; 这一句。

  因而将static应用到递归函数作用可想而知。在将需要作为递归函数间作为“桥梁"的变量利用static进行初始化,每一次递归都会保留"桥梁变量"的值。

  总结

  所谓递归函数,重点是如何处理函数调用自身是如何保证所需要的结果得以在函数间合理"传递",当然也有不需要函数之间传值得递归函数,例如:

  面对这样的函数,我们就不必大伤脑筋了。顺便说一句,深入理解变量引用相关知识对解决这类问题大有裨益。

最后给大家分享一个php实现递归与无限分类的方法,具体实现方法如下:

php给图片添加文字水印方法汇总 1:面向过程的编写方法//指定图片路径$src='.png';//获取图片信息$info=getimagesize($src);//获取图片扩展名$type=image_type_to_extension($info[2],false);//动态的把图片

PHP实现生成唯一会员卡号 在不查询数据库的情况下,每个会员登录进来会生成一个数字字母组合不重复的会员卡号。效果图如下:当我们要将一个庞大的数据进行编号时,而编

php 利用socket发送HTTP请求(GET,POST) 今天给大家带来的是如何利用socket发送GET,POST请求。我借用燕十八老师封装好的一个Http类给进行说明。在日常编程中相信很多人和我一样大部分时间是

标签: 递归 php

本文链接地址:https://www.jiuchutong.com/biancheng/284214.html 转载请保留说明!

上一篇:详解php 使用Callable Closure强制指定回调类型(php __callstatic)

下一篇:php给图片添加文字水印方法汇总(php怎么上传图片)

  • 扣非净利润和净利润的区别举例说明
  • 税务清算都交什么费用
  • 怎么进行增值税纳税申报
  • 各行业的税负率表2022
  • 政府预算年度
  • 2020年企业减免
  • 个人动产租赁所得税税率表最新
  • 公司账户的钱怎么取出来
  • 应付职工薪酬如何具体到个人
  • 加油站企业规模大小怎么划分
  • 不是本单位职工可以报销差旅费吗
  • 城市维护建设税税率
  • 个人机械租赁费税率
  • 以土地,房屋用地为主
  • 发了工资了
  • 汽车装饰用品大全进货
  • 企业发生的哪些业务可以使用简易计税法
  • 工资薪金所得个人所得税税率表
  • linux的sh
  • 苹果Mac系统怎么用光盘安装
  • mac小技巧
  • 银行利息为什么只算10个月
  • 消耗性生物资产如何结转成本
  • linux中gzip的用法
  • 货物运输业增值税专用发票可以抵扣吗
  • mmc.exe是什么进程
  • window显示我的电脑
  • mce文件是什么软件
  • nvm for windows
  • 税金及附加也是费用吗
  • 只有发票没有合同可以做账吗
  • 老生常谈的近义词
  • 用友应收系统凭证冲销后查询不到怎么办
  • 拯救你的方法
  • sql server2014使用
  • 信息技术服务费的税率是多少
  • 劳务费发票是个人的吗
  • 下月初可以认证上月的发票么
  • 办理地税手续费
  • 进项发票的作用
  • 最新出口退税申报需要哪些资料
  • 银行承兑汇票是什么意思
  • 红字发票异常处理什么意思
  • 货代是否负责损失
  • 预付工程款该怎么记账
  • 交易性金融资产公允价值变动怎么算
  • 无法支付其他应付款核销条件
  • 贴现凭证是什么意思
  • 什么是当期损益和其他综合收益
  • 息税前利润是什么税之前
  • 账簿的保管年限有哪些规定
  • 工业企业应付账款怎么算
  • mysql 5.7.21安装教程
  • win8系统连接vpn失败提示错误代码807的解决方法
  • Windows 9 Storage Sense储存功能更多图像
  • ie10和ie11
  • ubuntu 10.04安装
  • ubuntu12.04 amd64系统中lamp环境搭建方法
  • linux find 查找文件并重命名
  • bootcamp安装windows一直小白杠
  • 腾讯linux服务器
  • win101903更新安装失败
  • linux系统的内存分配和回收采用什么算法?
  • linux中vi替换
  • win8 屏幕键盘
  • win10更新补丁后键盘失灵
  • linux创建vg
  • win7系统屏幕保护设置禁用如何开启
  • cocos2dx 2.2.2
  • perl -pi
  • incaseformat查杀
  • mono为什么不能用了
  • unity3d项目
  • 动态生成类对象
  • jq中attr用法
  • js图片预览
  • 物业费增值税税率5%
  • 土地评估报告书
  • 大走访 方案
  • 天津环保网站官网
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设