导读PHP中很多原理和算法都是一样的,但是我们在操作过程中会通过比较和递归再实现,下面就由爱站技术频道小编介绍php 算法之实现相对路径的实例吧!php 算法之实现相对路径的实例算出相对路径(相同的目录可以忽略用../

PHP中很多原理和算法都是一样的,但是我们在操作过程中会通过比较和递归再实现,下面就由爱站技术频道小编介绍php 算法之实现相对路径的实例吧!

php 算法之实现相对路径的实例

算出相对路径(相同的目录可以忽略用../ 或者 ./ 表示)

实现代码:

class Relatively{ 
  private function __construct(){ 
     
  } 
   
  public static function relaroot($path1,$path2){ 
    $rearray=array(); 
    $arr1=explode('/', dirname($path1)); 
    $arr2=explode('/', dirname($path2)); 
    for($i=0,$len=count($arr2)-1;$i<$len;$i++){ 
      if($arr1[$i]!=$arr2[$i]){ 
        break; 
      } 
      if($i==1){ 
        $rearray=array(); 
      } 
      if($i!=1 && $i<$len){ 
        $rearray=array_fill(0,$len-$i,'..'); 
      } 
      if($i==$len){ 
        $rearray=array('./'); 
      } 
    } 
    $reroot=array_merge($rearray,array_slice($arr2, $i)); 
    return implode('/', $reroot); 
  } 
} 
$path1="a/b/c/d/index.php"; 
$path2="/a/b/12/34/index1.php"; 
$a=Relatively::relaroot($path1, $path2); 
echo $a; 

上文是爱站技术频道小编介绍的php 算法之实现相对路径的实例,相信认真看完的朋友都已经懂了,可以为很多程序员节省下不少时间。


原文链接:https://js.aizhan.com/develop/php/11400.html
如有疑问请与原作者联系