Jadual Kandungan
PHP递归创建多级目录(一道面试题的解题过程),php递归
Rumah pembangunan bahagian belakang tutorial php PHP递归创建多级目录(一道面试题的解题过程),php递归_PHP教程

PHP递归创建多级目录(一道面试题的解题过程),php递归_PHP教程

Jul 12, 2016 am 09:05 AM
rekursi

PHP递归创建多级目录(一道面试题的解题过程),php递归

今天看到一道面试题,要写出一个可以创建多级目录的函数:


 

我的第一个感觉就是用递归创建,具体思路如下:

<span>function</span> Directory(<span>$dir</span><span>){

</span><span>    if</span>(<span>is_dir</span>(<span>$dir</span>) || @<span>mkdir</span>(<span>$dir</span>,0777)){ <span>//</span><span>查看目录是否已经存在或尝试创建,加一个@抑制符号是因为第一次创建失败,会报一个&ldquo;父目录不存在&rdquo;的警告。</span>

        <span>echo</span> <span>$dir</span>."创建成功<br>";   <span>//</span><span>输出创建成功的目录</span>
<span>
    }</span><span>else</span><span>{

        </span><span>$dirArr</span>=<span>explode</span>('/',<span>$dir</span>); <span>//</span><span>当子目录没创建成功时,试图创建父目录,用explode()函数以'/'分隔符切割成一个数组</span>

        <span>array_pop</span>(<span>$dirArr</span>); <span>//</span><span>将数组中的最后一项(即子目录)弹出来,</span>

        <span>$newDir</span>=<span>implode</span>('/',<span>$dirArr</span>); <span>//</span><span>重新组合成一个文件夹字符串</span>
<span>
        Directory(</span><span>$newDir</span>); <span>//</span><span>试图创建父目录</span>

        <span>if</span>(@<span>mkdir</span>(<span>$dir</span>,0777<span>)){

            </span><span>echo</span> <span>$dir</span>."创建成功<br>"<span>;

        } </span><span>//</span><span>再次试图创建子目录,成功输出目录名</span>
<span>
    }

}

Directory(</span>"A/B/C/D/E/F");
Salin selepas log masuk

输出结果如图:


但是可以看得出来,写得也太麻烦了,在手册里翻看文件函数,看到一个dirname()函数,其原型如下:

<p>string dirname ( string $path )</p>
<p>给出一个包含有指向一个文件的全路径的字符串,本函数返回去掉文件名后的目录名。 </p>
<p>在 Windows 中,斜线(/)和反斜线(\)都可以用作目录分隔符。在其它环境下是斜线(/)。</p>
Salin selepas log masuk

可以稍稍地优化一下:

<span>function</span> Directory(<span>$dir</span><span>){

    </span><span>if</span>(<span>is_dir</span>(<span>$dir</span>) || @<span>mkdir</span>(<span>$dir</span>,0777<span>)){ 

        </span><span>echo</span> <span>$dir</span>."创建成功<br>"<span>;   

    }</span><span>else</span><span>{

        Directory(</span><span>dirname</span>(<span>$dir</span><span>));

        </span><span>if</span>(@<span>mkdir</span>(<span>$dir</span>,0777<span>)){

            </span><span>echo</span> <span>$dir</span>."创建成功<br>"<span>;

        }

    }

}</span>
Salin selepas log masuk

效果一样。


之后我在在网上搜一下答案,找到一个异常精辟的:

<span>function</span>  Directory( <span>$dir</span><span> ){    

     </span><span>return</span>   <span>is_dir</span> ( <span>$dir</span> )  or  Directory(<span>dirname</span>( <span>$dir</span> ))  and   <span>mkdir</span> ( <span>$dir</span> , 0777<span>);

}</span>
Salin selepas log masuk

现在来解释一下整个函数:

先介绍一下PHP中逻辑运算符的优先级顺序:&& > || > and > or,即符号型>字母型,AND型>OR型,所以函数体可以看成:

is_dir ( $dir )  or  (Directory(dirname( $dir ))  and   mkdir ( $dir , 0777));

先判断目标目录是否存在,若存在,依or的短路特性,后面的整体被短路,跳过执行;若目标目录不存在,则执行后面的函数体:

Directory(dirname( $dir ))  and   mkdir ( $dir , 0777) 

我考虑了一下先进行递归的用意:先执行递归,意在确认其父目录(dirname($dir))都已经创建完毕,使后面的mkdir()函数不会创建子目录时找不到父目录发出警告。

进入递归深处后,确认最深处的根目录存在后,从根目录向下依次创建目录。


 

最后,建议要找工作的亲们,去网上找些大公司面试题做一下,毕竟他们考得较为综合较深,在学习知识的时候,也刷一下题,另外也一定要做一下,因为很容易眼高手低,一开始的函数,我优化了好几遍才能正常使用。

以后我也会再找些有意思的面试题跟大家分享。

如果您觉得本博文对您有帮助,您可以推荐或关注我,如果您有什么问题,可以在下方留言讨论,谢谢。

www.bkjia.comtruehttp://www.bkjia.com/PHPjc/1068263.htmlTechArticlePHP递归创建多级目录(一道面试题的解题过程),php递归 今天看到一道面试题,要写出一个可以创建多级目录的函数: 我的第一个感觉就...
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

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

AI Hentai Generator

AI Hentai Generator

Menjana ai hentai secara percuma.

Alat panas

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Pelaksanaan rekursif fungsi C++: Adakah terdapat had untuk kedalaman rekursif? Pelaksanaan rekursif fungsi C++: Adakah terdapat had untuk kedalaman rekursif? Apr 23, 2024 am 09:30 AM

Kedalaman rekursi fungsi C++ adalah terhad, dan melebihi had ini akan mengakibatkan ralat limpahan tindanan. Nilai had berbeza antara sistem dan penyusun, tetapi biasanya antara 1,000 dan 10,000. Penyelesaian termasuk: 1. Pengoptimuman rekursi ekor; 2. Panggilan ekor;

Adakah ungkapan lambda C++ menyokong rekursi? Adakah ungkapan lambda C++ menyokong rekursi? Apr 17, 2024 pm 09:06 PM

Ya, ungkapan Lambda C++ boleh menyokong rekursi dengan menggunakan std::function: Gunakan std::function untuk menangkap rujukan kepada ungkapan Lambda. Dengan rujukan yang ditangkap, ungkapan Lambda boleh memanggil dirinya secara rekursif.

Pelaksanaan rekursif fungsi C++: Analisis perbandingan algoritma rekursif dan bukan rekursif? Pelaksanaan rekursif fungsi C++: Analisis perbandingan algoritma rekursif dan bukan rekursif? Apr 22, 2024 pm 03:18 PM

Algoritma rekursif menyelesaikan masalah berstruktur melalui fungsi panggilan kendiri Kelebihannya ialah ia mudah dan mudah difahami, tetapi kelemahannya ialah ia kurang cekap dan boleh menyebabkan limpahan timbunan Algoritma bukan rekursif mengelakkan pengulangan dengan menguruskan secara eksplisit struktur data timbunan Kelebihannya ialah ia lebih cekap dan mengelakkan limpahan, kelemahannya ialah kod itu mungkin lebih kompleks. Pilihan rekursif atau bukan rekursif bergantung kepada masalah dan kekangan khusus pelaksanaan.

Kira bilangan kejadian subrentetan secara rekursif dalam Java Kira bilangan kejadian subrentetan secara rekursif dalam Java Sep 17, 2023 pm 07:49 PM

Diberi dua rentetan str_1 dan str_2. Matlamatnya adalah untuk mengira bilangan kejadian subrentetan str2 dalam rentetan str1 menggunakan prosedur rekursif. Fungsi rekursif ialah fungsi yang memanggil dirinya dalam definisinya. Jika str1 ialah "Iknowthatyouknowthatiknow" dan str2 ialah "tahu" bilangan kejadian ialah -3 Mari kita fahami melalui contoh. Contohnya, input str1="TPisTPareTPamTP", str2="TP";

Program rekursif untuk mencari elemen minimum dan maksimum tatasusunan dalam C++ Program rekursif untuk mencari elemen minimum dan maksimum tatasusunan dalam C++ Aug 31, 2023 pm 07:37 PM

Kami mengambil tatasusunan integer Arr[] sebagai input. Matlamatnya adalah untuk mencari elemen terbesar dan terkecil dalam tatasusunan menggunakan kaedah rekursif. Memandangkan kami menggunakan rekursi, kami akan mengulangi keseluruhan tatasusunan sehingga kami mencapai panjang = 1 dan kemudian mengembalikan A[0], yang membentuk huruf asas. Jika tidak, elemen semasa dibandingkan dengan nilai minimum atau maksimum semasa dan nilainya dikemas kini secara rekursif untuk elemen berikutnya. Mari kita lihat pelbagai senario input dan output untuk −Input −Arr={12,67,99,76,32}; Nilai maksimum dalam tatasusunan: 99 Penjelasan &mi

Bagaimana untuk menyelesaikan ralat kedalaman rekursi maksimum Python? Bagaimana untuk menyelesaikan ralat kedalaman rekursi maksimum Python? Jun 24, 2023 pm 02:48 PM

Python ialah bahasa pengaturcaraan yang mudah dipelajari dan digunakan Walau bagaimanapun, apabila menggunakan Python untuk menulis fungsi rekursif, anda mungkin menghadapi ralat di mana kedalaman rekursi terlalu besar Pada masa ini, masalah ini perlu diselesaikan. Artikel ini akan menunjukkan kepada anda cara menyelesaikan ralat kedalaman rekursi maksimum Python. 1. Fahami kedalaman rekursi. Kedalaman rekursi merujuk kepada bilangan lapisan fungsi rekursif bersarang. Secara lalai dalam Python, had kedalaman rekursi ialah 1000. Jika bilangan aras rekursi melebihi had ini, sistem akan melaporkan ralat. Ralat ini sering dipanggil "ralat kedalaman rekursi maksimum"

Cara menggunakan pemprosesan borang Vue untuk melaksanakan sarang rekursif borang Cara menggunakan pemprosesan borang Vue untuk melaksanakan sarang rekursif borang Aug 11, 2023 pm 04:57 PM

Cara menggunakan pemprosesan borang Vue untuk melaksanakan sarang rekursif borang Pengenalan: Memandangkan kerumitan pemprosesan data bahagian hadapan dan pemprosesan borang terus meningkat, kami memerlukan cara yang fleksibel untuk mengendalikan borang yang kompleks. Sebagai rangka kerja JavaScript yang popular, Vue membekalkan kami banyak alatan dan ciri yang berkuasa untuk mengendalikan sarang rekursif borang. Artikel ini akan memperkenalkan cara menggunakan Vue untuk mengendalikan borang kompleks tersebut dan melampirkan contoh kod. 1. Sarang rekursif bentuk Dalam sesetengah senario, kita mungkin perlu menangani sarang rekursif.

Penjelasan terperinci tentang rekursi fungsi C++: aplikasi rekursi dalam pemprosesan rentetan Penjelasan terperinci tentang rekursi fungsi C++: aplikasi rekursi dalam pemprosesan rentetan Apr 30, 2024 am 10:30 AM

Fungsi rekursif ialah teknik yang memanggil dirinya berulang kali untuk menyelesaikan masalah dalam pemprosesan rentetan. Ia memerlukan syarat penamatan untuk mengelakkan rekursi tak terhingga. Rekursi digunakan secara meluas dalam operasi seperti pembalikan rentetan dan pemeriksaan palindrom.

See all articles