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

首頁(yè) > 開發(fā) > PHP > 正文

PHP常用的排序和查找算法

2024-05-04 23:38:34
字體:
來(lái)源:轉(zhuǎn)載
供稿:網(wǎng)友

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

本文匯總了常見的php排序算法和查找,在進(jìn)行算法設(shè)計(jì)的時(shí)候有不錯(cuò)的借鑒價(jià)值。現(xiàn)分享給大家供參考之用。具體如下:

 

 
  1. <?php 
  2. /** 
  3. * PHP最常用的四個(gè)排序方法及二種查找方法 
  4. * 下面的排序方法全部都通過(guò)測(cè)試 
  5. * auther : soulence 
  6. * date : 2015/06/20 
  7. */ 
  8.  
  9. //PHP冒泡排序法 
  10. function bubbleSort(&$arr){ 
  11. //這是一個(gè)中間變量 
  12. $temp=0; 
  13. //我們要把數(shù)組,從小到大排序 
  14. //外層循環(huán) 
  15. $flag=false;//這個(gè)優(yōu)化之后效率會(huì)很高,一般夠用 
  16. for($i=0;$i<count($arr)-1;$i++){ 
  17.  
  18. for($j=0;$j<count($arr)-1-$i;$j++){ 
  19. //說(shuō)明前面的數(shù)比后面的數(shù)大,就要交換 
  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. //已經(jīng)是有序了 
  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. //假設(shè)$i就是最小的數(shù) 
  35. $minVal=$arr[$i]; 
  36. //記錄我認(rèn)為的最小數(shù)的下標(biāo) 
  37. $minIndex=$i
  38. for($j=$i+1;$j<count($arr);$j++){ 
  39. //說(shuō)明我們認(rèn)為的最小值,不是最小 
  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. //先默認(rèn)下標(biāo)為0的這個(gè)數(shù)已經(jīng)是有序 
  51. for($i=1;$i<count($arr);$i++){ 
  52. //$insertVal是準(zhǔn)備插入的數(shù) 
  53. $insertVal=$arr[$i]; 
  54. //準(zhǔn)備先和誰(shuí)下標(biāo)為$inserIndex的比較 
  55. $inserIndex=$i-1; 
  56. //如果這個(gè)條件滿足,說(shuō)明我們還沒(méi)有找到適當(dāng)?shù)奈恢?/span> 
  57. while($inserIndex >= 0 && $insertVal < $arr[$inserIndex]){ 
  58. //同時(shí)把數(shù)后移 
  59. $arr[$inserIndex+1] = $arr[$inserIndex]; 
  60. $inserIndex--; 
  61. //插入(這時(shí)就給$inserIndex找到適當(dāng)?shù)奈恢茫?/span> 
  62. $arr[$inserIndex+1] = $insertVal
  63.  
  64.  
  65. //快速排序法 第一種寫法 不是我實(shí)現(xiàn)的 
  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. * 快速排序方法 第二種實(shí)現(xiàn)方法 自己實(shí)現(xiàn)的 
  93. * PHP快速排序方法 
  94. * $order asc 小到大 desc大到小 默認(rèn)是asc 
  95. * $order 的值只能為 asc desc 如果亂寫一個(gè)值也是按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 "找到了,下標(biāo)為=$i"
  131. $flag=true; 
  132. //查詢一次,如果多次就不要這個(gè) break; 
  133. if(!$flag){ 
  134. echo "查無(wú)此數(shù)"
  135.  
  136. //調(diào)用二分查找 
  137. $arr=array(0,90,900,99990);//注意,一定要是有序的 
  138. binarySwarch($arr,90,0,count($arr)-1); 
  139.  
  140. //二分查找函數(shù),它有一個(gè)前提,查找的數(shù)組必須是有序的 
  141. function binarySearch(&$arr,$findVal,$leftIndex,$rightIndex){ 
  142. //如果$rightIndex < $leftIndex條件成立,說(shuō)明沒(méi)有這個(gè)數(shù),則退出 
  143. if($rightIndex < $leftIndex){ 
  144. echo "找不到該數(shù)"
  145. return
  146. //首先找到中間這個(gè)數(shù) round是出于如果出現(xiàn)小數(shù),四舍五入 
  147. $middleIndex=round(($rightIndex+$leftIndex)/2); 
  148. //如果大于則向后面找 
  149. if($findVal > $arr[$middleIndex]){ 
  150. binarySearch($arr,$findVal,$middleIndex+1,$rightIndex); 
  151. //如果小于中間數(shù),則向前面找 
  152. }else if($findVal < $arr[$middleIndex]){ 
  153. binarySearch($arr,$findVal,$leftIndex,$middleIndex-1); 
  154. }else
  155. echo "找到這個(gè)數(shù)。下標(biāo)是$middleIndex"
  156. ?> 

希望本文所述排序算法和查找算法實(shí)例對(duì)大家的php程序設(shè)計(jì)有所幫助。

發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 久草成人在线 | 91色爱 | 欧美一级片一区 | 欧美极品欧美精品欧美视频 | 欧美女人天堂 | a黄毛片| 成人毛片av在线 | 免费一级毛片在线播放视频 | 亚洲五码在线观看视频 | 27xxoo无遮挡动态视频 | 久久手机在线视频 | chinese hd xxxx tube | 二区三区在线观看 | 国产成人在线免费观看视频 | 成人污在线 | 手机免费看一级片 | 国产一区二区免费 | 欧美一级淫片免费视频1 | 国内精品久久久久久影视8 嫩草影院在线观看网站成人 | 香蕉秀| ⅴideo裸体秀hd| av久草| 欧美aaaaa一级毛片在线 | av免费在线播放 | 国产一级一区 | 亚洲射逼 | 夜夜看 | 国产分类视频 | 深夜福利视频绿巨人视频在线观看 | 狠狠操夜夜爱 | 欧美熟videos肥婆 | 国产亚洲精品网站 | 久久大陆 | 中国洗澡偷拍在线播放 | 亚洲国产精品二区 | 国产精品久久久久一区二区 | 黄色大片在线观看 | 国产乱一区二区三区视频 | 久草在线公开视频 | 91精品最新国内在线播放 | 媚药按摩痉挛w中文字幕 |