Rumah > pembangunan bahagian belakang > tutorial php > 求将一段递归代码改成非递归形式

求将一段递归代码改成非递归形式

WBOY
Lepaskan: 2016-06-13 11:59:25
asal
833 orang telah melayarinya

求将一段递归代码改为非递归形式

<br />function delRecursive($id,$class_arr)<br />{<br />	if($id=="") $id=0;<br />	for($i=0;$i<count($class_arr);$i++){<br />		if($class_arr[$i][3]==$id){<br />		    $subid=$class_arr[$i][0];<br />		    $this->db->delete('tree', array('id' => $id));<br />		    $this->db->delete('tree', array('id' => $subid));		<br />			delRecursive($subid,$class_arr);<br />		}	<br />	}<br />}<br />
Salin selepas log masuk

------解决方案--------------------
怎么就不知道与人方便,与己方便的道理呢?

消除递归就是用自己的堆栈,代替系统的堆栈
$ar = array(<br />  array(  "1", "0", "顶级分类1",     "0", "1"),<br />  array("713", "0", "顶级分类2",     "0", "1"),<br />  array("716", "0", "一级子分类1", "713", "1"),<br />  array("718", "0", "顶级分类3",     "0", "1"),<br />  array("721", "0", "二级子分类1", "716", "1"),<br />);<br /><br />$id = 713;<br />delRecursive($id, $ar);<br />func($id, $ar);<br /><br />function func($id, $class_arr)<br />{<br />    if($id=="") $id=0;<br />    $st = array($id);<br />    do {<br />      $cnt = count($st);<br />      for($i=0;$i<count($class_arr);$i++){<br />        if(in_array($id = $class_arr[$i][3], $st)){<br />            $subid=$class_arr[$i][0];<br />            if(! in_array($subid, $st)) {<br />              $st[] = $subid;<br />echo "$id,$subid\n";   <br />//            $this->db->delete('tree', array('id' => $id));<br />//            $this->db->delete('tree', array('id' => $subid));    <br />//            delRecursive($subid,$class_arr);<br />            }<br />        }   <br />      }<br />    }while($cnt < count($st));<br />}<br /><br />function delRecursive($id, $class_arr)<br />{<br />    if($id=="") $id=0;<br />    for($i=0;$i<count($class_arr);$i++){<br />        if($class_arr[$i][3]==$id){<br />            $subid=$class_arr[$i][0];<br />//            $this->db->delete('tree', array('id' => $id));<br />//            $this->db->delete('tree', array('id' => $subid));    <br />echo "$id,$subid\n";   <br />            delRecursive($subid,$class_arr);<br />        }   <br />    }<br />}
Salin selepas log masuk

------解决方案--------------------

<br>$st = array($id);<br>do {<br>                $cnt = count($st);<br>                 for($i=0;$i<count></count>                    if(in_array($class_arr[$i][3], $st)){<br>                        $subid=$class_arr[$i][0];<br>                            if(!in_array($subid, $st)) {<br>                                $st[] = $subid;<br>                                $this->DB_MT->delete('tree', array('id' => $id));<br>                                $this->DB_MT->delete('tree', array('id' => $subid));<br>                            }<br>                        }   <br>                    }<br>}while($cnt 
                 
              
              
        
            
Salin selepas log masuk
Label berkaitan:
sumber:php.cn
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan