递归算法php,php递归算法经典实例「建议收藏」

递归算法php,php递归算法经典实例「建议收藏」PHP递归算法就是函数调用函数了操作非常的简单了,我们下面来给各位介绍PHP递归算法及实际的一些关于递归的用法。递归函数为自调用函数,在函数体内直接或间接自己调用自己,但需要设置自调用的条件,若满足条件,则调用函数本身,若不满足则终止本函数的自调用,然后把目前流程的主控权交回给上一层函数来执行,可能这样给大家讲解,还是很难明白,直接上例子functiontest($n){echo$n.”…

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

PHP递归算法就是函数调用函数了操作非常的简单了,我们下面来给各位介绍PHP递归算法及实际的一些关于递归的用法。

递归函数为自调用函数,在函数体内直接或间接自己调用自己,但需要设置自调用的条件,若满足条件,则调用函数本身,若不满足则终止本函数的自调用,然后把目前流程的主控权交回给上一层函数来执行,可能这样给大家讲解,还是很难明白,直接上例子function test ($n){

echo $n.” “;

if($n>0){

test($n-1);

}else{

echo “>”;

}

echo $n.” ”

}

test(2)

这个例子最终的输出结果是2 1 0>0 1 2

我解释下 为何输出是这样的

第一步,执行test(2),echo 2,然后因为2>0,执行test(1), 后面还有没来得及执行的echo 2

第二步,执行test(1),echo 1,然后因为1>0,执行test(0),同样后面还有没来得及执行的 echo 1

第三步,执行test(0),echo 0,执行test(0),echo 0, 此时0>0的条件不满足,不在执行test()函数,而是echo “>”,并且执行后面的 echo 0

此时函数已经不再调用自己,开始将流程的主控权交回给上一层函数来执行,也就是开始执行刚刚所有test()函数没来得及输出的最后一个echo,0的一层是1也就是输出1 1的上一层是2 也就是输出2 2没有山一层 所以呢 输出的内容就是2 1 0>0 1 2

如何考虑用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;

}

中序遍历二叉树void inorder (BinTree T){

if (T){

inorder(T->lchild);

printf(“%c”,T->data);

inorder(T->rchild);

}

}

Mysql

首先我们准备一张数据表class,记录商品分类信息。表中有三个字段,id:分类编号,主键自增长;title:分类名称;pid:所属上级分类id。

class表结构:CREATE TABLE IF NOT EXISTS `class` (

`id` mediumint(6) NOT NULL AUTO_INCREMENT,

`title` varchar(30) NOT NULL,

`pid` mediumint(6) NOT NULL DEFAULT ‘0’,

PRIMARY KEY (`id`)

) ENGINE=MyISAM DEFAULT CHARSET=utf8;

插入数据后,如图:

1440641488132426.jpg

根据不同的需求,我们提供两种不同格式的自定义函数,一种是返回字符串,一种是返回数组,两种函数都使用了递归方法。先看返回字符串格式的函数:function get_str($id = 0) {

global $str;

$sql = “select id,title from class where pid= $id”;

$result = mysql_query($sql);//查询pid的子类的分类

if($result && mysql_affected_rows()){//如果有子类

$str .= ”;

while ($row = mysql_fetch_array($result)) { //循环记录集

$str .= “

” . $row[‘id’] . “–” . $row[‘title’] . “”; //构建字符串

get_str($row[‘id’]); //调用get_str(),将记录集中的id参数传入函数中,继续查询下级

}

$str .= ”;

}

return $str;

}

以上函数get_str()通过递归,不断查询下级分类,并最终返回字符串,大家可以根据项目需求修改其中的str,最终生成一个无限分级列表:include_once(‘connect.php’); //连接数据库,connect.php文件自己写一个啊

echo get_str(0); //输出无限级分类

效果如:

1440641531425842.jpg

接着我们来看返回数组格式的函数,一样要使用递归:function get_array($id=0){

$sql = “select id,title from class where pid= $id”;

$result = mysql_query($sql);//查询子类

$arr = array();

if($result && mysql_affected_rows()){//如果有子类

while($rows=mysql_fetch_assoc($result)){ //循环记录集

$rows[‘list’] = get_array($rows[‘id’]); //调用函数,传入参数,继续查询下级

$arr[] = $rows; //组合数组

}

return $arr;

}

}

函数get_array()返回了数组,这是我们期待的,所以笔者推荐使用get_array()得到数组,这样一来,我们可以对数组进行任意操作,比如我们可以将数组转换成json格式的数据传给前端页面,前端页面可以通过解析json数据灵活展示分类信息。比如树形结构的分类列表,下拉分类列表等。include_once(‘connect.php’); //连接数据库

$list = get_array(0); //调用函数

print_r($list); //输出数组

如果要输出json格式的数据,则可使用:

1440641555554464.jpgecho json_encode($list);

本文原创发布php中文网,转载请注明出处,感谢您的尊重!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/169557.html原文链接:https://javaforall.net

(0)
上一篇 2022年8月11日 下午4:46
下一篇 2022年8月11日 下午5:00


相关推荐

  • Hwclock用法介绍

    Hwclock用法介绍Hwclock 介绍在 Linux 中有硬件时钟与系统时钟两种时钟 硬件时钟是指主机板上的时钟设备 也就是通常可在 BIOS 画面设定的时钟 系统时钟则是指 kernel 中的时钟 当 Linux 启动时 系统时钟会去读取硬件时钟的设定 之後系统时钟即独立运作 所有 Linux 相关指令与函数都是读取系统时钟的设定 hwclock 实现了 BIOS 和 linux 的时间同步 Hwclock 语法说明

    2026年3月18日
    2
  • linux 重启ftp的命令,linux开启ftp命令

    linux 重启ftp的命令,linux开启ftp命令ftp 服务器在网上较为常见 Linuxftp 命令的功能是用命令的方式来控制在本地机和远程机之间传送文件下面由学习啦小编为大家整理了 linux 下开启 ftp 命令的相关知识 希望对大家有所帮助 linux 下启动 FTP 命令的方式一般 linux 都有 vsftpd 吧 启动命令是 servicevsftp 你要限制匿名登录的话 修改它的配置文件 etc vsftpd vsftpd conf 把 an

    2026年3月17日
    1
  • Qwen3-8B vLLM 部署实践教程(AutoDL 平台)

    Qwen3-8B vLLM 部署实践教程(AutoDL 平台)

    2026年3月13日
    4
  • git的基本使用方法「建议收藏」

    git的基本使用方法「建议收藏」git的基本使用方法什么是git?git是目前世界上最先进的分布式版本控制系统。git与SVN的最主要区别?SVN是集中式版本控制系统,版本库是集中放在中央服务器的,而工作的时候用的都是自己的电脑,所以开始工作之前需要从中央服务器那里获取最新的版本,然后开始工作,工作完后,需要把自己所做的工作推送到中央服务器。集中式版本控制系统必须要联网才能工作,如果在局域网中,有足够的宽带,运行速度…

    2022年6月29日
    26
  • STLINK,ST-LINK Utility无法连接单片机

    STLINK,ST-LINK Utility无法连接单片机STLINK ST LINKUtility 无法连接单片机 keil ST LINKUtility 尝试连接最小系统板 但是无法连接 网上搜了很多教程 偶然看到一位道友说他连接空板子可以 有程序的不行 不知道为什么 因为我的板子之前也下载过程序 我就想起以前调试用过一个按住复位键的操作 就试了一下 果然成功了 确认连线正确就这几根 没的说按住复位键点击连接就这个键 一直按着 然后点击 S

    2026年3月17日
    1
  • pycharm双击打不开,没有反应,下列方法亲测有用!

    pycharm双击打不开,没有反应,下列方法亲测有用!关于这个问题,刚好我朋友安装的pycharm出现了同样地问题,激活成功教程安装一段时间后就突然打不开了,网上有许多的解决办法,我都试了一遍还是无果,后来自己发现了问题所在,首先给大家科普一下网上的方法,再放上我的,请大家耐心读完。亲测有效!!!第一种:1.打开C:\Windows\System32;以管理员身份运行cmd.exe;2.在打开的cmd窗口中,输入netshwinsockreset,按回车键;3.重启电脑;4.重启后,双击pycharm图标就能打开了!第二种:在Pycha

    2022年8月25日
    9

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号