国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 語言 > PHP > 正文

PHP面試常用算法(推薦)

2024-05-04 23:48:42
字體:
來源:轉載
供稿:網友

一、冒泡排序

基本思想:

對需要排序的數組從后往前(逆序)進行多遍的掃描,當發現相鄰的兩個數值的次序與排序要求的規則不一致時,就將這兩個數值進行交換。這樣比較小(大)的數值就將逐漸從后面向前面移動。

//冒泡排序

<?php  function mysort($arr)  {    for($i = 0; $i < count($arr); $i++)    {      $isSort = false;      for ($j=0; $j< count($arr) - $i - 1; $j++)       {        if($arr[$j] < $arr[$j+1])        {          $isSort = true;          $temp = $arr[$j];          $arr[$j] = $arr[$j+1];          $arr[$j+1] = $temp ;        }      }      if($isSort)      {        break;      }    }    return $arr;  }  $arr = array(3,1,2);  var_dump(mysort($arr));?>

二、快速排序

基本思想:

在數組中挑出一個元素(多為第一個)作為標尺,掃描一遍數組將比標尺小的元素排在標尺之前,將所有比標尺大的元素排在標尺之后,通過遞歸將各子序列分別劃分為更小的序列直到所有的序列順序一致。

//快速排序

<?php  //快速排序    function quick_sort($arr)     {      //先判斷是否需要繼續進行      $length = count($arr);      if($length <= 1)       {        return $arr;      }          $base_num = $arr[0];//選擇一個標尺 選擇第一個元素      //初始化兩個數組      $left_array = array();//小于標尺的      $right_array = array();//大于標尺的      for($i=1; $i<$length; $i++)       {      //遍歷 除了標尺外的所有元素,按照大小關系放入兩個數組內        if($base_num > $arr[$i])         {          //放入左邊數組          $left_array[] = $arr[$i];        }         else         {          //放入右邊          $right_array[] = $arr[$i];        }      }      //再分別對 左邊 和 右邊的數組進行相同的排序處理方式      //遞歸調用這個函數,并記錄結果      $left_array = quick_sort($left_array);      $right_array = quick_sort($right_array);      //合并左邊 標尺 右邊      return array_merge($left_array, array($base_num), $right_array);    }    $arr = array(3,1,2);    var_dump(quick_sort($arr));?>

三、二分查找

基本思想:

假設數據是按升序排序的,對于給定值x,從序列的中間位置開始比較,如果當前位置值等于x,則查找成功;若x小于當前位置值,則在數列的前半段中查找;若x大于當前位置值則在數列的后半段中繼續查找,直到找到為止。(數據量大的時候使用)

//二分查找

<?php  //二分查找  function bin_search($arr,$low,$high,$k)  {    if($low <= $high)    {      $mid = intval(($low + $high)/2);      if($arr[$mid] == $k)      {        return $mid;      }      else if($k < $arr[$mid])      {        return bin_search($arr,$low,$mid-1,$k);      }      else      {        return bin_search($arr,$mid+1,$high,$k);      }    }    return -1;  }  $arr = array(1,2,3,4,5,6,7,8,9,10);  print(bin_search($arr,0,9,3));?>

四、順序查找

基本思想:

從數組的第一個元素開始一個一個向下查找,如果有和目標一致的元素,查找成功;如果到最后一個元素仍沒有目標元素,則查找失敗。

//順序查找 

<?php  //順序查找  function seq_search($arr,$n,$k)  {    $array[$n] = $k;    for($i = 0;$i < $n; $i++)    {      if($arr[$i] == $k)      {        break;      }    }    if($i < $n)    {      return $i;    }    else    {      return -1;    }  }?>

五、寫一個函數,能夠遍歷一個文件下的所有文件和子文件夾

<?php    function my_scandir($dir)  {    $files = array();    if($handle = opendir($dir))    {      while (($file = readdir($handle))!== false)       {        if($file != '..' && $file != '.')        {          if(is_dir($dir."/".$file))          {            $files[$file]=my_scandir($dir."/".$file);          }          else          {            $files[] = $file;          }        }      }      closedir($handle);      return $files;    }  }  var_dump(my_scandir('../'));?>

六、寫一個函數,盡可能高效的從一個標準url中取出文件的擴展名

<?php  function getExt($url)  {    $arr = parse_url($url);//parse_url解析一個 URL 并返回一個關聯數組,包含在 URL 中出現的各種組成部分    //'scheme' => string 'http' (length=4)    //'host' => string 'www.sina.com.cn' (length=15)    //'path' => string '/abc/de/fg.php' (length=14)    //'query' => string 'id=1' (length=4)    $file = basename($arr['path']);// basename函數返回路徑中的文件名部分    $ext = explode('.', $file);    return $ext[count($ext)-1];  }  print(getExt('http://www.sina.com.cn/abc/de/fg.html.php?id=1'));?>

七、實現中文字符串截取無亂碼的方法

可使用mb_substr,但是需要確保在php.ini中加載了php_mbstring.dll,即確保“extension=php_mbstring.dll”這一行存在并且沒有被注釋掉,否則會出現未定義函 數的問題。

以上這篇PHP面試常用算法(推薦)就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持VeVb武林網。

 


注:相關教程知識閱讀請移步到PHP教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表

圖片精選

主站蜘蛛池模板: 淳安县| 滨海县| 南江县| 巴东县| 万全县| 双峰县| 南宫市| 老河口市| 大田县| 那曲县| 彭山县| 京山县| 连江县| 通化市| 永济市| 东阿县| 桐乡市| 石泉县| 二连浩特市| 嘉祥县| 固安县| 铜鼓县| 湟源县| 甘谷县| 灵石县| 玛纳斯县| 大石桥市| 日照市| 东丰县| 凌海市| 萨嘎县| 雷波县| 珠海市| 乳山市| 新龙县| 镇巴县| 前郭尔| 中超| 罗城| 璧山县| 龙川县|