PHP递归创建多级目录(一道面试题的解题过程),php递归
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>查看目录是否已经存在或尝试创建,加一个@抑制符号是因为第一次创建失败,会报一个“父目录不存在”的警告。</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");
输出结果如图:
但是可以看得出来,写得也太麻烦了,在手册里翻看文件函数,看到一个dirname()函数,其原型如下:
<p>string dirname ( string $path )</p> <p>给出一个包含有指向一个文件的全路径的字符串,本函数返回去掉文件名后的目录名。 </p> <p>在 Windows 中,斜线(/)和反斜线(\)都可以用作目录分隔符。在其它环境下是斜线(/)。</p>
可以稍稍地优化一下:
<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>
效果一样。
之后我在在网上搜一下答案,找到一个异常精辟的:
<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>
现在来解释一下整个函数:
先介绍一下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()函数不会创建子目录时找不到父目录发出警告。
进入递归深处后,确认最深处的根目录存在后,从根目录向下依次创建目录。
最后,建议要找工作的亲们,去网上找些大公司面试题做一下,毕竟他们考得较为综合较深,在学习知识的时候,也刷一下题,另外也一定要做一下,因为很容易眼高手低,一开始的函数,我优化了好几遍才能正常使用。
以后我也会再找些有意思的面试题跟大家分享。
如果您觉得本博文对您有帮助,您可以推荐或关注我,如果您有什么问题,可以在下方留言讨论,谢谢。

热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)

C++函数的递归深度受到限制,超过该限制会导致栈溢出错误。限制值因系统和编译器而异,通常在1000到10000之间。解决方法包括:1.尾递归优化;2.尾调用;3.迭代实现。

是的,C++Lambda表达式可以通过使用std::function支持递归:使用std::function捕获Lambda表达式的引用。通过捕获的引用,Lambda表达式可以递归调用自身。

递归算法通过函数自调用解决结构化的问题,优点是简洁易懂,缺点是效率较低且可能发生堆栈溢出;非递归算法通过显式管理堆栈数据结构避免递归,优点是效率更高且避免堆栈溢出,缺点是代码可能更复杂。选择递归或非递归取决于问题和实现的具体限制。

我们以整数数组Arr[]作为输入。目标是使用递归方法在数组中找到最大和最小的元素。由于我们使用递归,我们将遍历整个数组,直到达到长度=1,然后返回A[0],这形成了基本情况。否则,将当前元素与当前最小或最大值进行比较,并通过递归更新其值以供后续元素使用。让我们看看这个的各种输入输出场景−输入 −Arr={12,67,99,76,32};输出 −数组中的最大值:99解释 &mi

给定两个字符串str_1和str_2。目标是使用递归过程计算字符串str1中子字符串str2的出现次数。递归函数是在其定义中调用自身的函数。如果str1是"Iknowthatyouknowthatiknow",str2是"know"出现次数为-3让我们通过示例来理解。例如输入str1="TPisTPareTPamTP",str2="TP";输出Countofoccurrencesofasubstringrecursi

如何使用Vue表单处理实现表单的递归嵌套引言:随着前端数据处理和表单处理的复杂性不断增加,我们需要通过一种灵活的方式来处理复杂的表单。Vue作为一种流行的JavaScript框架,为我们提供了许多强大的工具和特性来处理表单的递归嵌套。本文将向大家介绍如何使用Vue来处理这种复杂的表单,并附上代码示例。一、表单的递归嵌套在某些场景下,我们可能需要处理递归嵌套的

Python是一门易学易用的编程语言,然而在使用Python编写递归函数时,可能会遇到递归深度过大的错误,这时就需要解决这个问题。本文将为您介绍如何解决Python的最大递归深度错误。1.了解递归深度递归深度是指递归函数嵌套的层数。在Python默认情况下,递归深度的限制是1000,如果递归的层数超过这个限制,系统就会报错。这种报错通常称为“最大递归深度错误

递归函数是一种在字符串处理中反复调用自身来解决问题的技术。它需要一个终止条件以防止无限递归。递归在字符串反转和回文检查等操作中被广泛使用。
