麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

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

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播放在线| av在线免费在线观看 | 久久网站热最新地址 | 亚洲最新色| 精品久久久一二三区播放播放播放视频 | 午夜a狂野欧美一区二区 | 久久艹国产精品 | 欧美日韩影视 | 国产精品视频在线观看免费 | 在线小视频国产 | 欧美精品亚洲人成在线观看 | 国产毛片毛片毛片 | 91网页视频入口在线观看 | 日日草夜夜操 | 99热高清 | 欧美精品日日鲁夜夜添 | 国产成人强伦免费视频网站 | 在线观看免费视频麻豆 | 污片在线观看视频 | 国产成人av在线播放 | 国产黄色毛片 | 色婷婷久久久亚洲一区二区三区 | 亚洲日本欧美 | 国产精品99久久免费观看 | 国产精品久久久久一区二区 | 成人免费一区二区三区在线观看 | 久久久入口 | 欧美精品一区二区久久 | 国产精品999在线观看 | 成人不卡免费视频 | 免费网站看v片在线a | 大片毛片 | 亚洲一区二区在线 | 特级黄毛片 | 日本成人二区 |