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

首頁 > 開發 > PHP > 正文

PHP常用的排序和查找算法

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

這篇文章主要介紹了PHP四種基本排序算法和兩種查找算法示例,本文用一個實例講解冒泡排序法、快速排序法、選擇排序法、插入排序法的使用,需要的朋友可以參考下

本文匯總了常見的php排序算法和查找,在進行算法設計的時候有不錯的借鑒價值。現分享給大家供參考之用。具體如下:

 

 
  1. <?php 
  2. /** 
  3. * PHP最常用的四個排序方法及二種查找方法 
  4. * 下面的排序方法全部都通過測試 
  5. * auther : soulence 
  6. * date : 2015/06/20 
  7. */ 
  8.  
  9. //PHP冒泡排序法 
  10. function bubbleSort(&$arr){ 
  11. //這是一個中間變量 
  12. $temp=0; 
  13. //我們要把數組,從小到大排序 
  14. //外層循環 
  15. $flag=false;//這個優化之后效率會很高,一般夠用 
  16. for($i=0;$i<count($arr)-1;$i++){ 
  17.  
  18. for($j=0;$j<count($arr)-1-$i;$j++){ 
  19. //說明前面的數比后面的數大,就要交換 
  20. if($arr[$j]>$arr[$j+1]){ 
  21. $temp=$arr[$j]; 
  22. $arr[$j]=$arr[$j+1]; 
  23. $arr[$j+1]=$temp
  24. $flag=true; 
  25. if(!$flag){ 
  26. //已經是有序了 
  27. break
  28. $flag=false; 
  29.  
  30. //PHP選擇排序法 效率比冒泡要高 
  31. function selectSort(&$arr){ 
  32. $temp=0; 
  33. for($i=0;$i<count($arr)-1;$i++){ 
  34. //假設$i就是最小的數 
  35. $minVal=$arr[$i]; 
  36. //記錄我認為的最小數的下標 
  37. $minIndex=$i
  38. for($j=$i+1;$j<count($arr);$j++){ 
  39. //說明我們認為的最小值,不是最小 
  40. if($minVal>$arr[$j]){ 
  41. $minVal=$arr[$j]; 
  42. $minIndex=$j
  43. //最后交換 
  44. $temp=$arr[$i]; 
  45. $arr[$i]=$arr[$minIndex]; 
  46. $arr[$minIndex]=$temp
  47.  
  48. //插入排序法(小到大排序) 效率又比 選擇排序法要高一些 
  49. function insertSort(&$arr){ 
  50. //先默認下標為0的這個數已經是有序 
  51. for($i=1;$i<count($arr);$i++){ 
  52. //$insertVal是準備插入的數 
  53. $insertVal=$arr[$i]; 
  54. //準備先和誰下標為$inserIndex的比較 
  55. $inserIndex=$i-1; 
  56. //如果這個條件滿足,說明我們還沒有找到適當的位置 
  57. while($inserIndex >= 0 && $insertVal < $arr[$inserIndex]){ 
  58. //同時把數后移 
  59. $arr[$inserIndex+1] = $arr[$inserIndex]; 
  60. $inserIndex--; 
  61. //插入(這時就給$inserIndex找到適當的位置) 
  62. $arr[$inserIndex+1] = $insertVal
  63.  
  64.  
  65. //快速排序法 第一種寫法 不是我實現的 
  66. function quickSort($left,$right,&$arr){ 
  67. $l=$left
  68. $r=$right
  69. $pivot$arr[($left+$right)/2]; 
  70. while($l<$r){ 
  71. while($arr[$l]<$pivot){ 
  72. $l++; 
  73. while($arr[$r]>$pivot){ 
  74. $r--; 
  75. if($l>=$r){ 
  76. break
  77.  
  78. $temp=$arr[$l]; 
  79. $arr[$l]=$arr[$r]; 
  80. $arr[$r]=$temp
  81. if($arr[$l]==$pivot){ 
  82. --$r
  83. if($arr[$r]==$pivot){ 
  84. ++$l
  85. if($l==$r){ 
  86. $l++; 
  87. $r--; 
  88. if($left<$r) quickSort($left,$r,$arr); 
  89. if($right>$l) quickSort($l,$right,$arr); 
  90.  
  91. /** 
  92. * 快速排序方法 第二種實現方法 自己實現的 
  93. * PHP快速排序方法 
  94. * $order asc 小到大 desc大到小 默認是asc 
  95. * $order 的值只能為 asc desc 如果亂寫一個值也是按asc排序的 
  96. */ 
  97. function quickSort2($arr,$order = 'asc'
  98. if(count($arr) <= 1) 
  99. return $arr
  100.  
  101. $arr_left = $arr_right = array(); 
  102.  
  103. $val = $arr[0];unset($arr[0]); 
  104.  
  105. foreach ($arr as $v) { 
  106. if(strtolower($order) == 'desc'){ 
  107. if($v < $val
  108. $arr_right[] = $v
  109. else 
  110. $arr_left[] = $v
  111. }else
  112. if($v > $val
  113. $arr_right[] = $v
  114. else 
  115. $arr_left[] = $v
  116.  
  117. $arr_left = quickSort($arr_left,$order); 
  118. $arr_right = quickSort($arr_right,$order); 
  119.  
  120. return array_merge($arr_left,array($val),$arr_right); 
  121.  
  122.  
  123. //下面是查找 
  124. $arr=array(46,90,900,0,-1); 
  125. //這是按順序查詢 
  126. function search(&$arr,$findVal){  
  127. $flag=false; 
  128. for($i=0;$i<count($arr);$i++){ 
  129. if($findVal==$arr[$i]){ 
  130. echo "找到了,下標為=$i"
  131. $flag=true; 
  132. //查詢一次,如果多次就不要這個 break; 
  133. if(!$flag){ 
  134. echo "查無此數"
  135.  
  136. //調用二分查找 
  137. $arr=array(0,90,900,99990);//注意,一定要是有序的 
  138. binarySwarch($arr,90,0,count($arr)-1); 
  139.  
  140. //二分查找函數,它有一個前提,查找的數組必須是有序的 
  141. function binarySearch(&$arr,$findVal,$leftIndex,$rightIndex){ 
  142. //如果$rightIndex < $leftIndex條件成立,說明沒有這個數,則退出 
  143. if($rightIndex < $leftIndex){ 
  144. echo "找不到該數"
  145. return
  146. //首先找到中間這個數 round是出于如果出現小數,四舍五入 
  147. $middleIndex=round(($rightIndex+$leftIndex)/2); 
  148. //如果大于則向后面找 
  149. if($findVal > $arr[$middleIndex]){ 
  150. binarySearch($arr,$findVal,$middleIndex+1,$rightIndex); 
  151. //如果小于中間數,則向前面找 
  152. }else if($findVal < $arr[$middleIndex]){ 
  153. binarySearch($arr,$findVal,$leftIndex,$middleIndex-1); 
  154. }else
  155. echo "找到這個數。下標是$middleIndex"
  156. ?> 

希望本文所述排序算法和查找算法實例對大家的php程序設計有所幫助。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 堆龙德庆县| 甘德县| 张家川| 芷江| 忻城县| 娄烦县| 泉州市| 邵阳县| 九龙县| 洛南县| 河南省| 定襄县| 会东县| 祁东县| 阿勒泰市| 绍兴县| 略阳县| 柳林县| 开平市| 杭锦旗| 东平县| 自贡市| 剑河县| 从化市| 新竹市| 贞丰县| 桂阳县| 安乡县| 和龙市| 南京市| 克什克腾旗| 佛学| 峨眉山市| 太仆寺旗| 西和县| 阿城市| 冕宁县| 汉中市| 山阳县| 汝阳县| 开鲁县|