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

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

May 23, 2016 pm 04:41 PM


<?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으로 문의하세요.

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

인기 기사

R.E.P.O. 에너지 결정과 그들이하는 일 (노란색 크리스탈)
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 최고의 그래픽 설정
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 아무도들을 수없는 경우 오디오를 수정하는 방법
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)