亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 開發 > PHP > 正文

PHP常用的排序和查找算法

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

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

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

 

 
  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程序設計有所幫助。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国产91精品黑色丝袜高跟鞋| 国产精品亚洲视频在线观看| 国产精品亚洲美女av网站| 国语自产偷拍精品视频偷| 国产精品视频一| 欧洲成人在线视频| 欧美日韩在线免费观看| 久久久欧美一区二区| 日韩精品在线免费播放| 成人福利在线视频| 91在线直播亚洲| 日本在线精品视频| 欧美国产日韩一区二区在线观看| 国产aⅴ夜夜欢一区二区三区| 17婷婷久久www| 97激碰免费视频| 欧美猛交ⅹxxx乱大交视频| 亚洲欧洲日本专区| 中文字幕不卡在线视频极品| 国内精品久久久| 亚洲free性xxxx护士hd| 91丝袜美腿美女视频网站| 国产精品久久久久久一区二区| 久久久久久久久久久久av| 亚洲精选在线观看| 欧美黄色小视频| 国产精品综合久久久| 午夜精品视频在线| 国产成人涩涩涩视频在线观看| 91chinesevideo永久地址| 日韩中文有码在线视频| 久久视频精品在线| 亚洲一级黄色片| 夜夜狂射影院欧美极品| 欧美精品videosex牲欧美| 日韩在线视频观看正片免费网站| 亚洲丝袜一区在线| 欧美激情综合色综合啪啪五月| 2018中文字幕一区二区三区| 韩日精品中文字幕| 久久视频中文字幕| 久久综合久久美利坚合众国| 91精品啪aⅴ在线观看国产| 97久久精品国产| 亚洲精品国产欧美| 一本色道久久88精品综合| 亚洲成av人片在线观看香蕉| 日韩中文字幕视频在线观看| 97碰碰碰免费色视频| 国产精品欧美激情| 久久精品亚洲精品| 亚洲大胆人体在线| 一本大道亚洲视频| 久久久久中文字幕2018| 日韩在线免费视频观看| 欧美在线精品免播放器视频| 亚洲精品在线视频| 日本一区二区三区四区视频| 亚洲人成网7777777国产| 国产伦精品一区二区三区精品视频| 精品视频在线播放免| 精品久久久久久久久久国产| 国产女人精品视频| 国产亚洲欧美视频| 色噜噜狠狠色综合网图区| 欧美洲成人男女午夜视频| 2019国产精品自在线拍国产不卡| 国产欧美精品一区二区| 国产精品亚洲一区二区三区| 精品久久国产精品| 国产一区二区三区视频免费| 在线日韩欧美视频| 久久99亚洲精品| 亚洲精品国产suv| 欧美高清视频免费观看| 性色av一区二区三区红粉影视| 日韩在线视频线视频免费网站| 中文字幕亚洲欧美日韩在线不卡| 亚洲免费人成在线视频观看| 91精品在线一区| 亚洲国产精品字幕| 亚洲人成在线观看| 日韩av电影免费观看高清| 正在播放欧美视频| 亚洲成人黄色在线| 亚洲欧洲中文天堂| 国产精品亚洲精品| 成人免费看吃奶视频网站| 一区二区欧美在线| 国产一区二区三区网站| 成人国产精品一区二区| 欧美主播福利视频| 日韩风俗一区 二区| 亚洲级视频在线观看免费1级| 久久免费国产精品1| 亚洲国产日韩欧美在线99| 不卡中文字幕av| 久久久黄色av| 欧美性猛交xxxx久久久| 97在线精品国自产拍中文| 亚洲欧美一区二区三区四区| 亚洲欧美激情四射在线日| 久久人人爽人人爽人人片av高请| 亚洲成人动漫在线播放| 亚洲欧美在线看| 大胆人体色综合| 国内精品久久久久久久| 久久天堂av综合合色| 欧美精品999| 青青草原成人在线视频| 欧洲成人性视频| 乱亲女秽乱长久久久| 欧美成aaa人片免费看| 欧美美最猛性xxxxxx| 日韩性xxxx爱| 少妇久久久久久| 久久国产精品久久精品| 欧美另类69精品久久久久9999| 亚洲日本成人网| 欧美性xxxxhd| 国产欧美精品一区二区三区介绍| 久久精品国产久精国产思思| 欧美华人在线视频| 成人国产精品久久久久久亚洲| 永久免费毛片在线播放不卡| 精品国产户外野外| 国产精品第一第二| 77777亚洲午夜久久多人| 精品久久久av| 国产精品露脸av在线| 国产欧美日韩免费看aⅴ视频| 欧美日韩国产第一页| 国产成人精品久久二区二区| 亚洲精品一区中文字幕乱码| 亚洲女人被黑人巨大进入al| 日韩在线视频中文字幕| 亚洲韩国日本中文字幕| 欧美日韩亚洲网| 午夜精品美女自拍福到在线| 亚洲精选中文字幕| 欧美日韩美女在线观看| 精品无人区乱码1区2区3区在线| 国产精品18久久久久久麻辣| 亚洲国产精彩中文乱码av| 欧美寡妇偷汉性猛交| 日韩高清av一区二区三区| 色综合久久中文字幕综合网小说| 亚洲a中文字幕| 日韩成人av一区| 精品国产乱码久久久久久虫虫漫画| 欧美成人激情视频| 亚洲国产精品电影| 一区二区三区亚洲| 欧美成人精品h版在线观看| xxxxx成人.com| 日韩av成人在线观看| 日韩一区在线视频| 日韩黄色在线免费观看| 中文字幕在线日韩| 日韩精品中文字幕在线| 久久香蕉国产线看观看av| 这里只有精品在线观看| 欧美精品精品精品精品免费| 国产精品日日做人人爱|