a亚洲精品_精品国产91乱码一区二区三区_亚洲精品在线免费观看视频_欧美日韩亚洲国产综合_久久久久久久久久久成人_在线区

首頁 > 學院 > 邏輯算法 > 正文

PHP常用算法

2020-03-22 18:56:22
字體:
來源:轉載
供稿:網友
在日常的PHP開發環境中,我們可以通過一些常用的PHP算法,來更有效的解決一些問題,或者說通過知道了解一些算法,掌握這些算法的核心思想,PHP的問題也就迎刃而解。

一、冒泡排序

基本思想:

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

//冒泡排序

<?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開發中比較常用的算法分享給大家,希望能夠幫助大家。

相關文章:

PHP常用算法和數據結構示例

以上就是PHP常用算法的詳細內容,更多請關注 其它相關文章!

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 亚洲一区二区三区视频 | 久草精品在线 | 欧美视频一区二区 | 香蕉大人久久国产成人av | 国产精品久久久久久吹潮 | 色综合久久久久 | 91中文字幕在线观看 | 欧洲精品| 福利电影在线观看 | 精品乱码一区二区 | 国产精品一区二区三区四区 | 国产视频网 | 黄色免费网站 | 亚洲高清中文字幕 | 野狼在线社区2017入口 | 久久精品视 | 黄色一级大片网站 | 一本色道久久综合亚洲精品高清 | 97超碰免费在线 | 精品国产一区二区三区久久影院 | 久久久欧美 | 久久久国产视频 | 成人在线免费观看 | 欧美精品在线观看 | 综合一区 | 成人精品网| 精品国产乱码久久久久久蜜柚 | 日本视频在线播放 | 91在线成人| 国产精品美乳一区二区免费 | 欧美一区二区免费 | 精品99在线 | 精品一区视频 | 久久99精品久久久久蜜臀 | 国产成人亚洲欧 | 玖玖操| 午夜av亚洲女人剧场se | 日韩福利在线观看 | 久久精品国产99国产精品 | 国产精品久久久久久久久久妇女 | 久久久久久久国产精品 |