php递归实例
递归做为一种算法在程序设计语言中广泛应用。 一个过程或函数在其定义或说明中有直接或间接调用自身的一种方法,它通常把一个大型复杂的问题层层转化为一个与原问题相似的规模较小的问题来求解,递归策略只需少量的程序就可描述出解题过程所需要的多次重复计算,大大地减少了程序的代码量。
下面举4个递归的实例:
<?php          /*         递归的实例         1、统计数组元素个数       php也可以直接使用count($arr,1) 来计算多维数组的元素的个数         2、统计文件和文件夹数量         3、删除文件或文件夹         用到的系统函数:file_exists()检查目录或者文件是否存在 unlink()删除文件 rmdir()删除目录         4、无限极分类的排序     */     /**     * 递归共计数组元素个数     * @param array $arr 统计的数组     * @return boolean|int  如果失败返回false,成功返回数组的元素个数     */     function conarr($arr){         function funtmp($arr,$sum=0){             if(is_array($arr)){                 $sum=count($arr);             }else{                 return count($arr);             }             foreach($arr as $k=> $v){ if(is_array($v)){ $sum += funtmp($v,$sum); } } return $sum; } return funtmp($arr); } // $arr = array(1,2,3,4,array(1,2,3,array(0,3))); // echo conarr($arr).'<br>'; // echo count($arr,1); /** * 递归统计指定目录的子文件的个数和文件夹个数 * @param $dirname string 目录路径 * @return array|boolean 返回包含子文件个数和文件夹个数的数组,失败返回false */ function condir($dirname,$data = array('dirnum'=>0,'filenum'=>0)){ if(!is_dir($dirname)){ return false; } $dir = opendir($dirname); //打开句柄 readdir($dir);//读取点 readdir($dir);//读取点 while($filename = readdir($dir)){ $newfile = $dirname.'/'.$filename;//拼接子文件名 if(is_dir($newfile)){ $data['dirnum']++; $data['dirnum']+=condir($newfile)['dirnum']; $data['filenum']+=condir($newfile)['filenum']; }else{ $data['filenum']++; } } return $data; } //$a = condir('C:\wamp\www\test'); //var_dump($a); /** * 删除文件或者文件夹 * @param string $dirname 文件路径 * @return boolean 删除成功返回true,失败返回false */ function delDir($dirname){ if(!file_exists($dirname)){return false;} if($dir = opendir($dirname)){ while($filename = readdir($dir)){ if($filename !="."&& $filename !='..'){ $subFile = $dirname.'/'.$filename; if(is_dir($subFile)){ delDir($subFile); } if(is_file($subFile)){ unlink($subFile); } } } closedir($dir); rmdir($dirname); } if(!file_exists($dirname)){ return true; }else{ return false; } } //echo delDir('C:\wamp\www\test'); //无限极分类排序,父类后跟子类 function getlist($cate,$pid=0,$html="------",$i=0){ $i++; $list = array(); foreach($cate as $val){ if($val['pid']==$pid){ $val['html']=str_repeat($html,$i-1); $list[]=$val; $list = array_merge($list,getlist($cate,$val['id'],$html,$i)); } } return $list; } ?>
以上就介绍了php递归实例,包括了方面的内容,希望对PHP教程有兴趣的朋友有所帮助。

Alat AI Hot

Undresser.AI Undress
Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover
Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool
Gambar buka pakaian secara percuma

Clothoff.io
Penyingkiran pakaian AI

AI Hentai Generator
Menjana ai hentai secara percuma.

Artikel Panas

Alat panas

Notepad++7.3.1
Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina
Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1
Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6
Alat pembangunan web visual

SublimeText3 versi Mac
Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Topik panas



Penggunaan pulangan dalam bahasa C ialah: 1. Untuk fungsi yang jenis nilai pulangannya adalah batal, anda boleh menggunakan pernyataan pulangan untuk menamatkan pelaksanaan fungsi lebih awal 2. Untuk fungsi yang jenis nilai pulangannya tidak batal, fungsi bagi penyataan pulangan adalah untuk menamatkan pelaksanaan fungsi Hasilnya dikembalikan kepada pemanggil 3. Menamatkan pelaksanaan fungsi lebih awal, kita boleh menggunakan penyataan pulangan untuk menamatkan pelaksanaan fungsi lebih awal jika fungsi tidak mengembalikan nilai.

Kod sumber: publicclassReturnFinallyDemo{publicstaticvoidmain(String[]args){System.out.println(case1());}publicstaticintcase1(){intx;try{x=1;returnx;}akhirnya{x=3;}}}# Output Output kod di atas hanya boleh membuat kesimpulan: return dilaksanakan sebelum akhirnya. Mari kita lihat apa yang berlaku pada tahap bytecode. Yang berikut memintas sebahagian kod bait kaedah case1 dan membandingkan kod sumber untuk menganotasi maksud setiap arahan dalam

Tajuk: Contoh menggunakan fungsi Array.Sort untuk mengisih tatasusunan dalam Teks C#: Dalam C#, tatasusunan ialah struktur data yang biasa digunakan dan operasi pengisihan tatasusunan selalunya diperlukan. C# menyediakan kelas Array, yang mempunyai kaedah Isih untuk menyusun tatasusunan dengan mudah. Artikel ini akan menunjukkan cara menggunakan fungsi Array.Sort dalam C# untuk mengisih tatasusunan dan memberikan contoh kod khusus. Pertama, kita perlu memahami penggunaan asas fungsi Array.Sort. Susunan.Jadi

Apabila pengaturcaraan dalam PHP, kita selalunya perlu menggabungkan tatasusunan. PHP menyediakan fungsi array_merge() untuk melengkapkan penggabungan tatasusunan, tetapi apabila kunci yang sama wujud dalam tatasusunan, fungsi ini akan menimpa nilai asal. Untuk menyelesaikan masalah ini, PHP juga menyediakan fungsi array_merge_recursive() dalam bahasa, yang boleh menggabungkan tatasusunan dan mengekalkan nilai kunci yang sama, menjadikan reka bentuk program lebih fleksibel. array_merge

Dalam PHP, terdapat banyak fungsi tatasusunan berkuasa yang boleh menjadikan operasi tatasusunan lebih mudah dan lebih pantas. Apabila kita perlu menggabungkan dua tatasusunan ke dalam tatasusunan bersekutu, kita boleh menggunakan fungsi array_combine PHP untuk mencapai operasi ini. Fungsi ini sebenarnya digunakan untuk menggabungkan kekunci satu tatasusunan sebagai nilai tatasusunan lain ke dalam tatasusunan bersekutu baharu. Seterusnya, kami akan menerangkan cara menggunakan fungsi array_combine dalam PHP untuk menggabungkan dua tatasusunan menjadi tatasusunan bersekutu. Ketahui tentang array_comb

Gula sintaks persediaan Vue3.2 ialah gula sintaks masa kompilasi yang menggunakan gabungan API dalam satu komponen fail (SFC) untuk menyelesaikan persediaan yang rumit dalam Vue3.0 Pembolehubah, fungsi dan kandungan yang diisytiharkan yang diperkenalkan oleh import didedahkan melalui pulangan, supaya ia boleh digunakan dalam Vue3.0 Masalah dalam penggunaan 1. Tidak perlu mengembalikan pembolehubah yang diisytiharkan, fungsi dan kandungan yang diperkenalkan semasa penggunaan Anda boleh menggunakan gula sintaksis //import kandungan yang diperkenalkan import{getToday }from'./utils'//variable constmsg='Hello !'//function function

Fungsi JavaScript menyediakan dua antara muka untuk berinteraksi dengan dunia luar Parameter berfungsi sebagai pintu masuk untuk menerima maklumat luaran berfungsi sebagai saluran keluar untuk menyalurkan kembali hasil operasi kepada dunia luar. Artikel berikut akan membawa anda memahami nilai pulangan fungsi JavaScript dan menganalisis secara ringkas penggunaan penyata pulangan saya harap ia akan membantu anda!

Penggunaan pulangan dalam JavaScript memerlukan contoh kod khusus Dalam JavaScript, pernyataan pulangan digunakan untuk menentukan nilai yang dikembalikan daripada fungsi. Ia bukan sahaja boleh digunakan untuk menamatkan pelaksanaan fungsi, ia juga boleh mengembalikan nilai ke tempat di mana fungsi itu dipanggil. Pernyataan pulangan mempunyai kegunaan biasa berikut: Mengembalikan nilai Pernyataan pulangan boleh digunakan untuk mengembalikan nilai ke tempat di mana fungsi dipanggil. Berikut ialah contoh mudah: functionadd(a,b){
