今儿我跟大伙聊聊咋用 PHP 搞递归算法,这玩意儿听着挺玄乎,搞明白,也就那么回事儿。咱一步步来,看看我是咋弄的。开始之前,我琢磨着啥是递归?简单说,就是咱写一个函数,...
今儿我跟大伙聊聊咋用 PHP 搞递归算法,这玩意儿听着挺玄乎,搞明白,也就那么回事儿。咱一步步来,看看我是咋弄的。
开始之前,我琢磨着啥是递归?简单说,就是咱写一个函数,然后这个函数自己个儿还调用自己,这就叫递归。听着有点绕口,但别急,咱慢慢来。
第一步:咱得有个想法,要用递归解决啥问题?我想半天,就想弄一个最简单的,就是算一个数的阶乘。比如 5 的阶乘,就是 54321,等于 120。
第二步:开始动手写函数。我先定义一个函数,叫 factorial,它有一个参数 $n。这个函数是这么运作的:
如果 $n 等于 0,那就返回 1。因为 0 的阶乘是 1 嘛这是规定好的。
如果 $n 大于 0,那就返回 $n 乘以 factorial($n-1)。这就是递归的关键,你看,这个函数调用它自己,不过参数变成 $n-1。
第三步:测试一下。我写一个调用,传入参数 5,看看输出是运行一遍,输出 120,跟我算的没差!
第四步:我把代码改进一下,加入输入验证。如果用户输入一个负数,那咱得告诉他,这数不能算阶乘。所以在函数开头,我又加一个判断:如果 $n 小于 0,就返回一个错误信息。
第五步:我还试试用静态变量来实现递归。就是定义一个静态变量,每次递归的时候都更新这个变量的值。这种方式也能实现递归,但我个人觉得没有直接用函数调用自己那么直观。
第六步:我还解利用全局变量的方式实现。这个就跟静态变量有点像,不过用的是全局变量。这种方式我不咋推荐,因为全局变量多,代码就乱套。
我把我的实践过程和代码都整理一下,写这篇分享。希望对大伙儿有所帮助。记住,递归这玩意儿,虽然听着高级,但只要你动手去写,去试,也没那么难。关键是要理解它的原理,就是自己调用自己,一层一层地往下递进,直到满足某个条件,然后再一层一层地返回来。掌握这个,你就掌握递归的精髓!
实践出真知,希望大家多多动手,有啥问题可以给我留言,咱一起探讨!