搜索热词

递归函数在编程中是比较常用的一类函数,其特点是函数自身可以调用自身,但是必须在调用自身前有条件判断,否则会导致无限调用下去。本文列出了三种递归函数实现方法,第一种利用引用做参数,第二种利用全局变量,第三种利用静态变量,理解此类问题需要有点基础,包括对全局变量,引用,静态变量的理解,也需对他们的作用范围有所理解。在这不废话了,具体介绍请看下文。

第一种方法:利用引用做参数

先不管引用做不做参数,必须先明白引用到底是什么?引用不过是指两个不同名的变量指向同一块存储地址。本来每个变量有各自的存储地址,赋值删除各行其道。

现在可好,两个变量共享一块存储地址。

$a=&$b; 。实际上指的是

$a不管不顾自己原来的存储地址,非要和

$b共享一室了。因而任何对存储地址数值的改变都会影响两个值。

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

代码如下:

上面的例子非常简答,以

a<10作为判断条件,条件成立,则把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的值。相信很多人认为是

12345678910吧,其实不然,是

1098765432。为什么呢?因为函数还没执行echo a前就进行了下一次的函数递归。

真正执行

echo a是当

a<10条件不满足的时候,

echo a,返回

result,对于上一层而言,执行完递归函数,开始执行本层的

echo $a,依次类推。

第二种方法:利用全局变量

利用全局变量完成递归函数,请确保你确实理解什么是全局变量

。global在函数内申明变量不过是外部变量的同名引用。变量的作用范围仍然在本函数范围内。改变这些变量的值,外部同名变量的值自然也改变了。但一旦用了

&,同名变量不再是同名引用。利用全局变量实现递归函数没必要理解到这么深的一层,还保持原有对全局变量的看法就可以顺理成章理解递归函数。

代码如下:

第三种方法:利用静态变量

我们常常在类中见到

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

举个栗子:

代码如下:

请问这一段代码的执行结果是多少?是

00000么?必然不是。是

01234。首先第一次调用

test(),static对

$count进行初始化,其后每一次执行完都会保留

$count的值,不再进行初始化,相当于直接忽略了

static $count=0; 这一句。

因而将static应用到递归函数作用可想而知。在将需要作为递归函数间作为“桥梁"的变量利用

static进行初始化,每一次递归都会保留

"桥梁变量"的值。

代码如下:

总结

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

代码如下:

test($a);

}

}

下面通过一段代码演示一下PHP使用递归函数实现数字累加的方法。

代码如下所示:

代码如下:

面对PHP递归函数,不必要伤脑筋,深入的理解变量引用相关知识对解决此类问题很有帮助,以上内容就是PHP递归函数三种实现方法及如何实现数字累加的全部内容,希望对大家今后的学习有所帮助。

总结

如果觉得编程之家网站内容还不错,欢迎将编程之家网站推荐给程序员好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。

相关文章

猜你在找的PHP相关文章

只要在PHP文件头输入这两段话即可实现1 header("Content-type:application/vnd.ms-excel");2 header("Conten

在php中使用 json_encode() 内置函数可以使用得php中的数据更好的与其它语言传递与使用。这个函数的功能是将数组转换成json数据存储格式:1 'Balla_兔子',

Rewirte主要的功能就是实现URL的跳转和隐藏真实地址,基于Perl语言的正则表达式规范。平时帮助我们实现拟静态,拟目录,域名跳转,防止盗链等一、Apache配置: 1、支持httpd.conf

在上篇基于PHP采集数据入库程序(一)中提到采集新闻信息页的列表数据,接下来讲讲关于采集新闻具体内容这是上篇博客的最终数据表截图:接下来要做的操作就是从数据库中读取所需要采集的URL,进行页面抓取就行

先说下关于数据库备份与恢复的原理:1、查找所有表->2、查找所有字段->3、查找所有数据->4、生成SQL备份注意点:2=>需要列出所有字段名,字段类型等相关信息3=>读

关于PHP上传文件的函数类库,网上有许多封装很完善,大家直接拿来用就可以。本文章只是说下关于上传原理和简单的上传操作,老鸟就无视了哈^_^~还有一些安全性判断比如:服务端限制能接收图片类型的文件,而客

1、PHP上传压缩包并解压的大概流程:普通上传功能->上传到服务器->加载系统组件->找到上传的文件并执行解压命令->成功解压到目录2、php执行系统命令的几类函数:(1)sy

在前一篇文章里讲到了关于PHP文件上传原理和简单操作举例是单文件上传。http://www.cnblogs.com/lichenwei/p/3879566.html其实多文件上传和单文件上传大同小异,

php递归实现sum函数,php递归函数三种实现方法及如何实现数字累加相关推荐

  1. C++函数指针的三种定义方法

    一.C的函数指针定义方法 定义一个两个int参数,一个int返回值的函数指针类型 typedef int (*func)(int,int) 定义一个两个int参数,一个int返回值的函数指针 int ...

  2. 交换函数swap的三种实现方法

    本文采用三种方式实现两个数之间的交换,分别是①借助辅助变量temp的swap函数,②采用加减法的swap函数 ,③使用异或运算的swap函数. 现在直奔主题: 1.借助辅助变量temp的swap函数 ...

  3. 迷宫问题的三种求解方法(递归求解、回溯求解和队列求解)

    目录 一.迷宫问题的三种求解方法 递归求解 回溯求解 队列求解 二.华为迷宫问题 一.迷宫问题的三种求解方法 在迷宫问题中,给定入口和出口,要求找到路径.本文将讨论三种求解方法,递归求解.回溯求解和队 ...

  4. JavaScript中函数的三种定义方法

    JavaScript中函数定义的三种方法. 函数的三种定义方法分别是:函数定义语句.函数直接量表达式和Function()构造函数的方法.下面依次介绍这几种方法具体怎么实现. 1. 函数定义语句 // ...

  5. python函数拟合不规则曲线_python 对任意数据和曲线进行拟合并求出函数表达式的三种解决方案...

    第一种是进行多项式拟合,数学上可以证明,任意函数都可以表示为多项式形式.具体示例如下. ###拟合年龄 import numpy as np import matplotlib.pyplot as p ...

  6. C++容器的insert()函数有以下三种用法: 最终*it=val;

    C++容器的insert()函数有以下三种用法: 最终*it=val; //用法1:在指定位置it前"插入"值为val的元素,返回指向这个元素的迭代器, iterator inse ...

  7. 将python中的小数直接进位的函数_python保留小数位的三种实现方法

    python保留小数位的三种实现方法 前言 保留小数位是我们经常会碰到的问题,尤其是刷题过程中.那么在python中保留小数位的方法也非常多,但是笔者的原则就是什么简单用什么,因此这里介绍几种比较简单 ...

  8. 第二周项目1函数参数传递的三种方式

    /* .*Copyright (c) 2014,烟台大学计算机学院 *All right reserved. *文件名称:函数参数传递的三种方式.cpp *作者:彭子竹 *完成日期:2015年9月11 ...

  9. 冒泡法排序函数c语言,【C语言】冒泡法排序的三种实现方法

    冒泡法的三种排序方法: 1.数组排序 #include//#includeint main() { int i; int j; int tmp; int arr[8] = { 1, 3, 5, 7, ...

最新文章

  1. Eclipse不自动编译 设置后重新编译仍然没有编译
  2. 8086PC机的内存地址空间分配
  3. layui table 列覆盖
  4. NYOJ 49 开心的小明
  5. 在Jenkins中获取GitHub对应Repository的Resource Code
  6. form表单中的input有哪些类型
  7. Struts2中过滤器,拦截器,监听器他们之间有什么区别?
  8. Linux E325: ATTENTION Found a swap file by the name “./.backu.sh.swp“
  9. C# 事务提交(非数据库)
  10. 信息奥赛一本通(1325:【例7.4】 循环比赛日程表)
  11. 处理2D图像和纹理——创建2D菜单界面
  12. 新出版书籍《Python预测之美:数据分析与算法实战》,送书活动!参与即可机会,获得一本实体书,中奖后可填写地址寄送。
  13. 使用cdn和npm引入的区别_带你体验 Vue2 和 Vue3 开发组件有什么区别
  14. Redis(RedisTemplate)使用string字符串
  15. 模拟手机通讯录管理系统
  16. MPChart的柱状图BarChart
  17. ubuntu终端快速清空回收站
  18. 自然语言处理-jieba
  19. GetDC与GetWindowDC 的区别
  20. python 费马检测

热门文章

  1. 值得学习的100个网站推广方法
  2. C#中同一解决方案下,一个项目调用另一个项目中的窗体
  3. 网络攻击中主动攻击和被动攻击分别指什么?
  4. PPT设计:PPT封面页9种设计布局/思维
  5. 【植物大战僵尸-3】种植物无CD
  6. 离散数学实验报告 实验3 欧拉路的确定
  7. oh-my-posh安装过程问题及注意事项
  8. 深入浅出说CUDA程序设计(二)
  9. 【每日一题】027 奇妙的数字
  10. 小学计算机老师师德师风演讲稿,小学教师师德师风演讲稿五篇