首页 >php教程 >PHP源码 >PHP常用的四种排序方法及二种查找方法

PHP常用的四种排序方法及二种查找方法

PHP中文网
PHP中文网原创
2016-05-23 16:41:111243浏览


<?php
/**
 * PHP最常用的四个排序方法及二种查找方法
 * 下面的排序方法全部都通过测试
 * auther : soulence
 * date : 2015/06/20
 */

//PHP冒泡排序法
function bubbleSort(&$arr){
  //这是一个中间变量
  $temp=0;
  //我们要把数组,从小到大排序
  //外层循环
  $flag=false;//这个优化之后效率会很高,一般够用
  for($i=0;$i<count($arr)-1;$i++){
  
      for($j=0;$j$arr[$j+1]){
                $temp=$arr[$j];
                $arr[$j]=$arr[$j+1];
                $arr[$j+1]=$temp;
			    $flag=true;
         }
      }
      if(!$flag){
	    //已经是有序了
		break;
	  }
	  $flag=false;
   }
}

//PHP选择排序法   效率比冒泡要高
function selectSort(&$arr){
   $temp=0;
   for($i=0;$i<count($arr)-1;$i++){
       //假设$i就是最小的数
       $minVal=$arr[$i];
       //记录我认为的最小数的下标
       $minIndex=$i;
       for($j=$i+1;$j$arr[$j]){
                 $minVal=$arr[$j];
                 $minIndex=$j;
           }
       }
       //最后交换
       $temp=$arr[$i];
       $arr[$i]=$arr[$minIndex];
       $arr[$minIndex]=$temp;
   }
}

//插入排序法(小到大排序)   效率又比  选择排序法要高一些
function insertSort(&$arr){
   //先默认下标为0的这个数已经是有序
   for($i=1;$i= 0 && $insertVal < $arr[$inserIndex]){
       //同时把数后移
            $arr[$inserIndex+1] = $arr[$inserIndex];
            $inserIndex--;
       }
       //插入(这时就给$inserIndex找到适当的位置)
       $arr[$inserIndex+1] = $insertVal;
   }
}

   
//快速排序法  第一种写法  不是我实现的
function quickSort($left,$right,&$arr){
     $l=$left;
	 $r=$right;
	 $pivot= $arr[($left+$right)/2];
     while($l<$r){
	     while($arr[$l]$pivot){
		 	$r--;
		 }
		 if($l>=$r){
		 	break;
		 }
		 
		 $temp=$arr[$l];
		 $arr[$l]=$arr[$r];
		 $arr[$r]=$temp;
		 if($arr[$l]==$pivot){
		 	--$r;
		 }
		 if($arr[$r]==$pivot){
		 	++$l;
		 }
	 }
	 if($l==$r){
	    $l++;
		$r--;
	 }
	 if($left$l) quickSort($l,$right,$arr);
}

/**
 * 快速排序方法  第二种实现方法  自己实现的
 * PHP快速排序方法
 * $order asc  小到大  desc大到小  默认是asc
 * $order 的值只能为 asc desc 如果乱写一个值也是按asc排序的
 */
function quickSort2($arr,$order = &#39;asc&#39;)
{
  if(count($arr) <= 1)
    return $arr;

  $arr_left = $arr_right = array();

  $val = $arr[0];unset($arr[0]);

  foreach ($arr as $v) {
    if(strtolower($order) == &#39;desc&#39;){
      if($v < $val)
        $arr_right[] = $v;
      else
        $arr_left[] = $v;
    }else{
      if($v > $val)
        $arr_right[] = $v;
      else
        $arr_left[] = $v;
    }
  }

  $arr_left = quickSort($arr_left,$order);
  $arr_right = quickSort($arr_right,$order);

  return array_merge($arr_left,array($val),$arr_right);
}


//下面是查找
$arr=array(46,90,900,0,-1);
//这是按顺序查询
function search(&$arr,$findVal){	 
	$flag=false;
	for($i=0;$i<count($arr);$i++){
		if($findVal==$arr[$i]){
			echo "找到了,下标为=$i";
			$flag=true;
			//查询一次,如果多次就不要这个 break;
		}
	}
	if(!$flag){
		echo "查无此数";
	}
}

//调用二分查找
$arr=array(0,90,900,99990);//注意,一定要是有序的
binarySwarch($arr,90,0,count($arr)-1);

//二分查找函数,它有一个前提,查找的数组必须是有序的
function binarySearch(&$arr,$findVal,$leftIndex,$rightIndex){
	//如果$rightIndex < $leftIndex条件成立,说明没有这个数,则退出
	if($rightIndex < $leftIndex){
		echo "找不到该数";
		return;
	}
	//首先找到中间这个数  round是出于如果出现小数,四舍五入
	$middleIndex=round(($rightIndex+$leftIndex)/2);
	//如果大于则向后面找
	if($findVal >$arr[$middleIndex]){
		binarySearch($arr,$findVal,$middleIndex+1,$rightIndex);
		//如果小于中间数,则向前面找
	}else if($findVal < $arr[$middleIndex]){
		binarySearch($arr,$findVal,$leftIndex,$middleIndex-1);
	}else{
		echo "找到这个数。下标是$middleIndex";
	}
}

?>

                   

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn