关于递归算法的议论
关于递归算法的讨论
小弟是还没毕业的学生,现在在实习做一个项目,又遇到了递归问题,希望大家帮助!
问题很简单,经典的递归遍历数组的问题
<br /><?php<br />$arr=array(<br />'0'=>array( 'id'=>'1','name'=>'角色管理','pid'=>'0',),<br />'1'=>array( 'id'=>'2','name'=>'添加角色','pid'=>'1',),<br />'2'=>array( 'id'=>'3','name'=>'角色列表','pid'=>'2',),<br />'3'=>array( 'id'=>'4','name'=>'菜单管理','pid'=>'0',),<br />'4'=>array( 'id'=>'5','name'=>'前台管理','pid'=>'4',),<br />'5'=>array( 'id'=>'6','name'=>'添加','pid'=>'5',),<br />'6'=>array( 'id'=>'7','name'=>'修改','pid'=>'5',),<br />'7'=>array( 'id'=>'8','name'=>'列表','pid'=>'5',),<br />'8'=>array( 'id'=>'9','name'=>'后台管理','pid'=>'4',),<br />'9'=>array( 'id'=>'10','name'=>'添加','pid'=>'9',),<br />'10'=>array( 'id'=>'11','name'=>'修改','pid'=>'9',),<br />'11'=>array( 'id'=>'12','name'=>'列表','pid'=>'9',),<br />);<br />?><br />
就是这个样子,递归遍历,要生成的有两个结果。
一个是标准的层级关系的数组
还有一个是用于放到下拉列表中的,

另外,我查资料,发现还能用指针,学生道行尚浅,请各位多多指教!!!

------解决方案--------------------
<br><?php <br />/**<br>* 通用的树型类,可以生成任何树型结构<br> */<br>header("content-type:text/html;charset=utf-8");<br>class tree {<br> /**<br> * 生成树型结构所需要的2维数组<br> * @var array<br> */<br> public $arr = array();<br><br> /**<br> * 生成树型结构所需修饰符号,可以换成图片<br> * @var array<br> */<br> public $icon = array('│','├','└');<br> public $nbsp = " ";<br><br> /**<br> * @access private<br> */<br> public $ret = '';<br><br> /**<br> * 构造函数,初始化类<br> * @param array 2维数组,例如:<br> * array(<br> * 1 => array('id'=>'1','parentid'=>0,'name'=>'一级栏目一'),<br> * 2 => array('id'=>'2','parentid'=>0,'name'=>'一级栏目二'),<br> * 3 => array('id'=>'3','parentid'=>1,'name'=>'二级栏目一'),<br> * 4 => array('id'=>'4','parentid'=>1,'name'=>'二级栏目二'),<br> * 5 => array('id'=>'5','parentid'=>2,'name'=>'二级栏目三'),<br> * 6 => array('id'=>'6','parentid'=>3,'name'=>'三级栏目一'),<br> * 7 => array('id'=>'7','parentid'=>3,'name'=>'三级栏目二')<br> * )<br> */<br> public function __construct($arr=array()){<br> $this->arr = $arr;<br> $this->ret = '';<br> return is_array($arr);<br> }<br><br> /**<br> * 得到父级数组<br> * @param int<br> * @return array<br> */<br> public function get_parent($myid){<br> $newarr = array();<br> if(!isset($this->arr[$myid])) return false;<br> $pid = $this->arr[$myid]['parentid'];<br> $pid = $this->arr[$pid]['parentid'];<br> if(is_array($this->arr))<br> {<br> foreach($this->arr as $id => $a)<br> {<br> if($a['parentid'] == $pid) $newarr[$id] = $a;<br> }<br> }<br> return $newarr;<br> }<br><br> /**<br> * 得到子级数组<br> * @param int<br> * @return array<br> */<br> public function get_child($myid)<br> {<br> $a = $newarr = array();<br> if(is_array($this->arr))<br> {<br> foreach($this->arr as $id => $a)<br> {<br> if($a['parentid'] == $myid) $newarr[$id] = $a;<br> }<br> }<br> return $newarr ? $newarr : false;<br> }<br><br> /**<br> * 得到当前位置数组<br> * @param int<br> * @return array<br> */<br> public function get_pos($myid,&$newarr)<br> {<br> $a = array();<br> if(!isset($this->arr[$myid])) return false;<br> $newarr[] = $this->arr[$myid];<br> $pid = $this->arr[$myid]['parentid'];<br> if(isset($this->arr[$pid]))<br> {<br> $this->get_pos($pid,$newarr);<br> }<br> if(is_array($newarr))<br> {<br> krsort($newarr);<br> foreach($newarr as $v)<br> {<br> $a[$v['id']] = $v;<br> }<br> }<br> return $a;<br> }<br><br> /**<br> * 得到树型结构<br> * @param int ID,表示获得这个ID下的所有子级<br> * @param string 生成树型结构的基本代码,例如:"<option>\$spacer\$name</option>"<br> * @param int 被选中的ID,比如在做树型下拉框的时候需要用到<br> * @return string<br> */<br> public function get_tree($myid, $str, $sid = 0, $adds = '', $str_group = '')<br> {<br> $number=1;<br> $child = $this->get_child($myid);<br> print_r($child);<br> if(is_array($child))<br> {<br> $total = count($child);<br> foreach($child as $id=>$value)<br> {<br> $j=$k='';<br> if($number==$total)<br> {<br> $j .= $this->icon[2]; //如果是最后一个子级使用└<br> }else<div class="clear"> </div>

热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

Video Face Swap
使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热门文章

热工具

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

“你的组织要求你更改PIN消息”将显示在登录屏幕上。当在使用基于组织的帐户设置的电脑上达到PIN过期限制时,就会发生这种情况,在该电脑上,他们可以控制个人设备。但是,如果您使用个人帐户设置了Windows,则理想情况下不应显示错误消息。虽然情况并非总是如此。大多数遇到错误的用户使用个人帐户报告。为什么我的组织要求我在Windows11上更改我的PIN?可能是您的帐户与组织相关联,您的主要方法应该是验证这一点。联系域管理员会有所帮助!此外,配置错误的本地策略设置或不正确的注册表项也可能导致错误。即

Windows11将清新优雅的设计带到了最前沿;现代界面允许您个性化和更改最精细的细节,例如窗口边框。在本指南中,我们将讨论分步说明,以帮助您在Windows操作系统中创建反映您的风格的环境。如何更改窗口边框设置?按+打开“设置”应用。WindowsI转到个性化,然后单击颜色设置。颜色更改窗口边框设置窗口11“宽度=”643“高度=”500“>找到在标题栏和窗口边框上显示强调色选项,然后切换它旁边的开关。若要在“开始”菜单和任务栏上显示主题色,请打开“在开始”菜单和任务栏上显示主题

默认情况下,Windows11上的标题栏颜色取决于您选择的深色/浅色主题。但是,您可以将其更改为所需的任何颜色。在本指南中,我们将讨论三种方法的分步说明,以更改它并个性化您的桌面体验,使其具有视觉吸引力。是否可以更改活动和非活动窗口的标题栏颜色?是的,您可以使用“设置”应用更改活动窗口的标题栏颜色,也可以使用注册表编辑器更改非活动窗口的标题栏颜色。若要了解这些步骤,请转到下一部分。如何在Windows11中更改标题栏的颜色?1.使用“设置”应用按+打开设置窗口。WindowsI前往“个性化”,然

您是否在Windows安装程序页面上看到“出现问题”以及“OOBELANGUAGE”语句?Windows的安装有时会因此类错误而停止。OOBE表示开箱即用的体验。正如错误提示所表示的那样,这是与OOBE语言选择相关的问题。没有什么可担心的,你可以通过OOBE屏幕本身的漂亮注册表编辑来解决这个问题。快速修复–1.单击OOBE应用底部的“重试”按钮。这将继续进行该过程,而不会再打嗝。2.使用电源按钮强制关闭系统。系统重新启动后,OOBE应继续。3.断开系统与互联网的连接。在脱机模式下完成OOBE的所

任务栏缩略图可能很有趣,但它们也可能分散注意力或烦人。考虑到您将鼠标悬停在该区域的频率,您可能无意中关闭了重要窗口几次。另一个缺点是它使用更多的系统资源,因此,如果您一直在寻找一种提高资源效率的方法,我们将向您展示如何禁用它。不过,如果您的硬件规格可以处理它并且您喜欢预览版,则可以启用它。如何在Windows11中启用任务栏缩略图预览?1.使用“设置”应用点击键并单击设置。Windows单击系统,然后选择关于。点击高级系统设置。导航到“高级”选项卡,然后选择“性能”下的“设置”。在“视觉效果”选

在Windows11上的显示缩放方面,我们都有不同的偏好。有些人喜欢大图标,有些人喜欢小图标。但是,我们都同意拥有正确的缩放比例很重要。字体缩放不良或图像过度缩放可能是工作时真正的生产力杀手,因此您需要知道如何对其进行自定义以充分利用系统功能。自定义缩放的优点:对于难以阅读屏幕上的文本的人来说,这是一个有用的功能。它可以帮助您一次在屏幕上查看更多内容。您可以创建仅适用于某些监视器和应用程序的自定义扩展配置文件。可以帮助提高低端硬件的性能。它使您可以更好地控制屏幕上的内容。如何在Windows11

许多用户在选择智能手表的时候都会选择的华为的品牌,其中华为GT3pro和GT4都是非常热门的选择,不少用户都很好奇华为GT3pro和GT4有什么区别,下面就就给大家介绍一下二者。华为GT3pro和GT4有什么区别一、外观GT4:46mm和41mm,材质是玻璃表镜+不锈钢机身+高分纤维后壳。GT3pro:46.6mm和42.9mm,材质是蓝宝石玻璃表镜+钛金属机身/陶瓷机身+陶瓷后壳二、健康GT4:采用最新的华为Truseen5.5+算法,结果会更加的精准。GT3pro:多了ECG心电图和血管及安

屏幕亮度是使用现代计算设备不可或缺的一部分,尤其是当您长时间注视屏幕时。它可以帮助您减轻眼睛疲劳,提高易读性,并轻松有效地查看内容。但是,根据您的设置,有时很难管理亮度,尤其是在具有新UI更改的Windows11上。如果您在调整亮度时遇到问题,以下是在Windows11上管理亮度的所有方法。如何在Windows11上更改亮度[10种方式解释]单显示器用户可以使用以下方法在Windows11上调整亮度。这包括使用单个显示器的台式机系统以及笔记本电脑。让我们开始吧。方法1:使用操作中心操作中心是访问
