> 백엔드 개발 > PHP 튜토리얼 > PHP는 일반적인 검색 및 정렬 알고리즘을 구현합니다.

PHP는 일반적인 검색 및 정렬 알고리즘을 구현합니다.

WBOY
풀어 주다: 2016-07-25 09:12:37
원래의
1046명이 탐색했습니다.

다음은 가장 일반적인 알고리즘 중 일부와 이를 PHP에서 구현하는 방법입니다.

1. 버블 정렬

  1. function bubble_sort($arr) {
  2. $n=count($arr);
  3. for( $ i=0;$i<$n-1;$i ){
  4. for($j=$i 1;$j<$n;$j ) {
  5. if($arr[$j] < ;$arr[$i]) {
  6. $temp=$arr[$i];
  7. $arr[$i]=$arr[$j];
  8. $arr[$j]= $ temp;
  9. }
  10. }
  11. }
  12. return $arr;
  13. }
코드 복사

2. 병합 정렬

  1. 함수 Merge(&$arr, $left, $mid, $right) {
  2. $i = $left ;
  3. $j = $mid 1;
  4. $k = 0;
  5. $temp = array();
  6. while ($i <= $mid && $j <= $right)
  7. {
  8. if ($arr[$i] <= $arr[$j])
  9. $temp[$k ] = $arr[$i ];
  10. else
  11. $ temp[$k ] = $arr[$j ];
  12. }
  13. while ($i <= $mid)
  14. $temp[$k ] = $arr[$i ];
  15. while ($j <= $right)
  16. $temp[$k ] = $arr[$j ];
  17. for ($i = $left, $j = 0; $i <= $right ; $i , $j )
  18. $arr[$i] = $temp[$j];
  19. }
  20. 함수 MergeSort(&$arr, $left, $right)
  21. {
  22. if ($left < $right)
  23. {
  24. $mid = Floor(($left $right) / 2);
  25. MergeSort($arr, $left, $mid);
  26. MergeSort($arr, $mid 1, $right);
  27. Merge($arr, $left, $mid, $right);
  28. }
  29. }
코드 복사

3. 이진 검색 - 재귀

  1. function bin_search($arr,$low,$high,$value) {
  2. if($low> ;$high)
  3. false 반환;
  4. else {
  5. $mid=floor(($low $high)/2);
  6. if($value==$arr[$mid])
  7. return $mid;
  8. elseif($value<$arr[$mid])
  9. return bin_search($arr,$low,$mid-1,$value);
  10. else
  11. return bin_search($arr,$mid 1,$high,$value);
  12. }
  13. }
코드 복사

4. 이진 검색 - 비재귀

  1. function bin_search($arr,$low,$high,$value) {
  2. while( $ low<=$high) {
  3. $mid=floor(($low $high)/2);
  4. if($value==$arr[$mid])
  5. return $mid;
  6. elseif($value<$arr[$mid])
  7. $high=$mid-1;
  8. else
  9. $low=$mid 1;
  10. }
  11. return false;
  12. }
코드 복사

5. 빠른 정렬

  1. functionquick_sort($arr) {
  2. $n=count($arr);
  3. if($ n<=1)
  4. $arr;
  5. $key=$arr[0];
  6. $left_arr=array();
  7. $right_arr=array();
  8. for($ 반환) i=1;$i<$n;$i ) {
  9. if($arr[$i]<=$key)
  10. $left_arr[]=$arr[$i];
  11. else
  12. $right_arr[]=$arr[$i];
  13. }
  14. $left_arr=quick_sort($left_arr);
  15. $right_arr=quick_sort($right_arr);
  16. return array_merge($ left_arr,array($key),$right_arr);
  17. }
코드 복사

6、选择排序

  1. function select_sort($arr) {
  2. $n=count($arr);
  3. for($ i=0;$i<$n;$i ) {
  4. $k=$i;
  5. for($j=$i 1;$j<$n;$j ) {
  6. if( $arr[$j]<$arr[$k])
  7. $k=$j;
  8. }
  9. if($k!=$i) {
  10. $temp=$arr[ $i];
  11. $arr[$i]=$arr[$k];
  12. $arr[$k]=$temp;
  13. }
  14. }
  15. return $arr;
  16. }
复代码

7、插入排序

  1. function insertSort($arr) {
  2. $n=count($arr);
  3. for($ i=1;$i<$n;$i ) {
  4. $tmp=$arr[$i];
  5. $j=$i-1;
  6. while($arr[$j]> ;$tmp) {
  7. $arr[$j 1]=$arr[$j];
  8. $arr[$j]=$tmp;
  9. $j--;
  10. if($ j<0)
  11. break;
  12. }
  13. }
  14. return $arr;
  15. }
复代码


원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿