PHP常用的排序和查找算法


Posted in PHP onAugust 06, 2015

本文汇总了常见的php排序算法和查找,在进行算法设计的时候有不错的借鉴价值。现分享给大家供参考之用。具体如下:

<?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<count($arr)-1-$i;$j++){
     //说明前面的数比后面的数大,就要交换
     if($arr[$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<count($arr);$j++){
      //说明我们认为的最小值,不是最小
      if($minVal>$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<count($arr);$i++){
    //$insertVal是准备插入的数
    $insertVal=$arr[$i];
    //准备先和谁下标为$inserIndex的比较
    $inserIndex=$i-1;
    //如果这个条件满足,说明我们还没有找到适当的位置
    while($inserIndex >= 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){
      $l++;
     }
     while($arr[$r]>$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<$r) quickSort($left,$r,$arr);
   if($right>$l) quickSort($l,$right,$arr);
}
 
/**
 * 快速排序方法 第二种实现方法 自己实现的
 * PHP快速排序方法
 * $order asc 小到大 desc大到小 默认是asc
 * $order 的值只能为 asc desc 如果乱写一个值也是按asc排序的
 */
function quickSort2($arr,$order = 'asc')
{
 if(count($arr) <= 1)
  return $arr;
 
 $arr_left = $arr_right = array();
 
 $val = $arr[0];unset($arr[0]);
 
 foreach ($arr as $v) {
  if(strtolower($order) == 'desc'){
   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";
  }
}
?>

希望本文所述排序算法和查找算法实例对大家的php程序设计有所帮助。

PHP 相关文章推荐
在php MYSQL中插入当前时间
Apr 06 PHP
php smarty模版引擎中变量操作符及使用方法
Dec 11 PHP
php htmlspecialchars加强版
Feb 16 PHP
深入理解require与require_once与include以及include_once的区别
Jun 05 PHP
PHP static局部静态变量和全局静态变量总结
Mar 02 PHP
smarty模板局部缓存方法使用示例
Jun 17 PHP
php的curl封装类用法实例
Nov 07 PHP
php+ajax无刷新分页实例详解
Dec 07 PHP
php获取今日开始时间和结束时间的方法
Feb 27 PHP
PHP实现的登录页面信息提示功能示例
Jul 24 PHP
Thinkphp5框架实现图片、音频和视频文件的上传功能详解
Aug 27 PHP
redis+php实现微博(一)注册与登录功能详解
Sep 23 PHP
PHP处理会话函数大总结
Aug 05 #PHP
PHP实现合并discuz用户
Aug 05 #PHP
举例详解PHP脚本的测试方法
Aug 05 #PHP
使用Thinkphp框架开发移动端接口
Aug 05 #PHP
wampserver改变默认网站目录的办法
Aug 05 #PHP
使用PHP接受文件并获得其后缀名的方法
Aug 05 #PHP
PHP合并discuz用户脚本的方法
Aug 04 #PHP
You might like
php程序之die调试法 快速解决错误
2009/09/17 PHP
php 批量生成html,txt文件的实现代码
2013/06/26 PHP
php验证身份证号码正确性的函数
2016/07/20 PHP
PHP实现的简单异常处理类示例
2017/05/04 PHP
js getBoundingClientRect() 来获取页面元素的位置
2010/11/25 Javascript
jquery中的常用事件bind、hover、toggle等示例介绍
2014/07/21 Javascript
JavaScript实现打开链接页面的方式汇总
2016/06/02 Javascript
Angularjs实现mvvm式的选项卡示例代码
2016/09/08 Javascript
Bootstrap select下拉联动(jQuery cxselect)
2017/01/04 Javascript
input输入密码变黑点密文的实现方法
2017/01/09 Javascript
vue使用watch 观察路由变化,重新获取内容
2017/03/08 Javascript
webpack配置文件和常用配置项介绍
2017/04/28 Javascript
JavaScript之解构赋值的理解
2019/01/30 Javascript
微信小程序wx.getUserInfo授权获取用户信息(头像、昵称)的实现
2020/08/19 Javascript
Antd-vue Table组件添加Click事件,实现点击某行数据教程
2020/11/17 Javascript
python多线程用法实例详解
2015/01/15 Python
Python学习小技巧之利用字典的默认行为
2017/05/20 Python
python正则表达式去除两个特殊字符间的内容方法
2018/12/24 Python
PyCharm 配置远程python解释器和在本地修改服务器代码
2019/07/23 Python
Python 异常处理Ⅳ过程图解
2019/10/18 Python
使用Rasterio读取栅格数据的实例讲解
2019/11/26 Python
python通过移动端访问查看电脑界面
2020/01/06 Python
Scrapy框架介绍之Puppeteer渲染的使用
2020/06/19 Python
Ratchet 模态框的实现
2020/08/19 HTML / CSS
为奢侈时尚带来了慈善元素:Olivela
2018/09/29 全球购物
OSPREY LONDON官网:英国本土皮具品牌
2019/05/31 全球购物
英国奢华护肤、美容和Spa品牌:Temple Spa
2019/11/02 全球购物
后勤园长自我鉴定
2013/10/17 职场文书
在职党员进社区活动总结
2014/07/05 职场文书
2014年大学生党员评议表自我评价
2014/09/20 职场文书
机关作风整顿个人整改措施思想汇报
2014/09/29 职场文书
2014年化验室工作总结
2014/11/21 职场文书
优秀党员先进事迹材料2016
2016/02/29 职场文书
如何撰写促销方案?
2019/07/05 职场文书
Java获取e.printStackTrace()打印的信息方式
2021/08/07 Java/Android
深入浅出讲解Java8函数式编程
2022/01/18 Java/Android