这里列出了几种PHP的排序算法的时间比较的结果,,希望对大家有所帮助

/** php 四种排序算法的时间与内置的sort排序比较* 3000个元素,四种算法的排序所用的时间比较* 冒泡排序 857.98192024231ms* 选择排序 903.74493598938ms* 插入排序 296.8270778656ms* 快速排序 15.607833862305ms* sort排序 0.95200538635254ms* 归并排序 14.61386680603ms* *//*
* @param 冒泡排序
* 它重复地走访过要排序的数列,一次比较两个元素,如果他们的顺序错误就把他们交换过来。
* 走访数列的工作是重复地进行直到没有再需要交换,也就是说该数列已经排序完成。
* */
function BubbleSort($arr) {$len = count($arr);//设置一个空数组 用来接收冒出来的泡//该层循环控制 需要冒泡的轮数for ($i = 1; $i < $len; $i++) {$flag = false;    //本趟排序开始前,交换标志应为假//该层循环用来控制每轮 冒出一个数 需要比较的次数for ($k = 0; $k < $len - $i; $k++) {//从小到大排序if ($arr[$k] > $arr[$k + 1]) {$tmp = $arr[$k + 1];$arr[$k + 1] = $arr[$k];$arr[$k] = $tmp;$flag = true;}}if(!$flag) return $arr;}
}/*
* @param 选择排序法
* 每一次从待排序的数据元素中选出最小(或最大)的一个元素,存放在序列的起始位置,直到全部待排序的数据元素排完。
* 选择排序是不稳定的排序方法(比如序列[5, 5, 3]第一次就将第一个[5]与[3]交换,导致第一个5挪动到第二个5后面)
* */
function selectSort($array){$temp = 0;for($i = 0;$i < count($array) - 1;$i++){$minVal = $array[$i]; //假设$i就是最小值$minValIndex = $i;for($j = $i+1;$j < count($array);$j++){if($minVal > $array[$j]){ //从小到大排列$minVal = $array[$j]; //找最小值$minValIndex = $j;}}$temp = $array[$i];$array[$i] = $array[$minValIndex];$array[$minValIndex] = $temp;}
}/*
* 插入排序法
* 每步将一个待排序的纪录,按其关键码值的大小插入前面已经排序的文件中适当位置上,直到全部插入完为止。
* 算法适用于少量数据的排序,时间复杂度为O(n^2)。是稳定的排序方法。
* */
function insertSort($array){ //从小到大排列
//先默认$array[0],已经有序,是有序表for($i = 1;$i < count($array);$i++){$insertVal = $array[$i]; //$insertVal是准备插入的数$insertIndex = $i - 1; //有序表中准备比较的数的下标while($insertIndex >= 0 && $insertVal < $array[$insertIndex]){$array[$insertIndex + 1] = $array[$insertIndex]; //将数组往后挪$insertIndex--; //将下标往前挪,准备与前一个进行比较
        }if($insertIndex + 1 !== $i){$array[$insertIndex + 1] = $insertVal;}}
}/*
* 快速排序法
* 通过一趟排序将要排序的数据分割成独立的两部分,其中一部分的所有数据都比另外一部分的所有数据都要小,
* 然后再按此方法对这两部分数据分别进行快速排序,整个排序过程可以递归进行,以此达到整个数据变成有序序列。
* */
function quickSort($array){if(!isset($array[1]))  return $array;$mid = $array[0]; //获取一个用于分割的关键字,一般是首个元素$leftArray = array();$rightArray = array();foreach($array as $v){if($v > $mid)$rightArray[] = $v; //把比$mid大的数放到一个数组里if($v < $mid)$leftArray[] = $v; //把比$mid小的数放到另一个数组里
    }$leftArray = quickSort($leftArray); //把比较小的数组再一次进行分割$leftArray[] = $mid; //把分割的元素加到小的数组后面,不能忘了它哦$rightArray = quickSort($rightArray); //把比较大的数组再一次进行分割return array_merge($leftArray,$rightArray); //组合两个结果
}/*
* 归并排序
* 归并排序是指将两个或两个以上有序的数列(或有序表),合并成一个仍然有序的数列(或有序表)。
* 这样的排序方法经常用于多个有序的数据文件归并成一个有序的数据文件。
* */
function mergeSort(&$arr) {$len = count($arr);//求得数组长度mSort($arr, 0, $len-1);return $arr;
}
//实际实现归并排序的程序
function mSort(&$arr, $left, $right) {if($left < $right) {//说明子序列内存在多余1个的元素,那么需要拆分,分别排序,合并//计算拆分的位置,长度/2 去整$center = floor(($left+$right) / 2);//递归调用对左边进行再次排序:
        mSort($arr, $left, $center);//递归调用对右边进行再次排序mSort($arr, $center+1, $right);//合并排序结果
        mergeArray($arr, $left, $center, $right);}
}
//将两个有序数组合并成一个有序数组
function mergeArray(&$arr, $left, $center, $right) {//设置两个起始位置标记$a_i = $left;$b_i = $center+1;while($a_i<=$center && $b_i<=$right) {//当数组A和数组B都没有越界时if($arr[$a_i] < $arr[$b_i]) {$temp[] = $arr[$a_i++];} else {$temp[] = $arr[$b_i++];}}//判断 数组A内的元素是否都用完了,没有的话将其全部插入到C数组内:while($a_i <= $center) {$temp[] = $arr[$a_i++];}//判断 数组B内的元素是否都用完了,没有的话将其全部插入到C数组内:while($b_i <= $right) {$temp[] = $arr[$b_i++];}//将$arrC内排序好的部分,写入到$arr内:for($i=0, $len=count($temp); $i<$len; $i++) {$arr[$left+$i] = $temp[$i];}
}$a = array_rand(range(1,10000), 3000); //生成3000个元素的随机数组
shuffle($a); //打乱数组的顺序
$t1 = microtime(true);
BubbleSort($a); //冒泡排序
$t2 = microtime(true);
echo "冒泡排序用时:".(($t2-$t1)*1000).'ms'."\n";$t3 = microtime(true);
selectSort($a); //选择排序
$t4 = microtime(true);
echo "选择排序用时:".(($t4-$t3)*1000).'ms'."\n";$t5 = microtime(true);
insertSort($a); //插入排序
$t6 = microtime(true);
echo "插入排序用时:".(($t6-$t5)*1000).'ms'."\n";$t7 = microtime(true);
quickSort($a); //快速排序
$t8 = microtime(true);
echo "快速排序用时:".(($t8-$t7)*1000).'ms'."\n";$t9 = microtime(true);
sort($a);
$t10 = microtime(true);
echo "sort排序用时:".(($t10-$t9)*1000)."ms"."\n";$t11 = microtime(true);
mergeSort($a);
$t12 = microtime(true);
echo "归并排序用时:".(($t12-$t11)*1000)."ms";

从时间上来看,快速排序和归并排序在时间上比较有优势,但是也比不上sort排序,归并排序比较占用内存!

转载于:https://www.cnblogs.com/jing1208/p/6289840.html

PHP的几种排序算法的比较相关推荐

  1. php主要算法设计,四种排序算法设计(PHP)

    标签 详细分析 /** * 四种排序算法设计(PHP) * * 1) 插入排序(Insertion Sort)的基本思想是: 每次将一个待排序的记录,按其关键字大小插入到前面已经排好序的子文件中的适当 ...

  2. 位图排序 大数据_干货分享:大话12种排序算法

    干货分享:大话12种排序算法 常见的排序算法: 快速排序.堆排序.归并排序.选择排序 插入排序.二分插入排序 冒泡排序.鸡尾酒排序 桶排序.计数排序.基数排序.位图排序 技能点: 1.归并排序在O(N ...

  3. Java常见的几种排序算法-插入、选择、冒泡、快排、堆排等

    本文就是介绍一些常见的排序算法.排序是一个非常常见的应用场景,很多时候,我们需要根据自己需要排序的数据类型,来自定义排序算法,但是,在这里,我们只介绍这些基础排序算法,包括:插入排序.选择排序.冒泡排 ...

  4. 归并排序改良 java_Java 八种排序算法总结

    image 前言 好久没复习基础了,写个冒泡排序都要想一会.感觉自己好像老了好多,今天手痒总结一下排序算法.目前网上博客普遍都有详细介绍,写的很清楚.说实话我是没必要再写一遍的,感觉就是在啰嗦.还是重 ...

  5. Java面试宝典系列之基础面试题-常见的几种排序算法-插入、选择、冒泡、快排、堆排等

    常见的几种排序算法-插入.选择.冒泡.快排.堆排: https://blog.csdn.net/zhangerqing/article/details/8831542

  6. java 算法 排序算法_Java七种排序算法以及实现

    Java常见七种排序算法以及实现 最近学习一些排序算法,怕自己以后忘记就打算整理起来供自己复习 萌新一枚学习Java没多久,以下仅供参考.如有错误希望大佬指正,欢迎大家在评论区交流探讨. 1.冒泡排序 ...

  7. 关于几种排序算法的时间性能比较

    以前经常看到各种排序算法,今天也对以下6种排序算法的时间性能做了一次测试: 测试代码地址 1. 冒泡排序 O(n^2) /** 冒泡排序 @Param {[]int} arr 整形切片 */ func ...

  8. Java常用的八种排序算法与代码实现

    在Java的时候,对于排序的应用需要熟练的掌握,这样才能够确保Java学习时候能够有扎实的基础能力.那Java有哪些排序算法呢?本文小千就来详细说说Java经典的8种排序算法. 经典的排序算法有八种, ...

  9. php常用的四种排序算法

    纯当练习,高手请绕过.以一维数组为例. 1.插入排序 思想: 每次将一个待排序的数据元素插入到前面已经排好序的数列中,使数列依然有序,知道待排序数据元素全部插入完为止. 示例: [初始关键字] [49 ...

最新文章

  1. 人工智能与智能系统的先驱人物
  2. hbase java框架_Hadoop学习笔记—15.HBase框架学习(基础实践篇)
  3. boost::histogram::accumulators用法的测试程序
  4. RMAN的一些术语解释
  5. Asp.net MVC 示例项目Suteki.Shop分析之---Model和Service
  6. CentOS服务器下nginx防盗链介绍与配置
  7. 关于·nowrap与width
  8. 自学python单片机编程-作为一个硬件工程师,你该学学Python了
  9. k8s部署zabbix_Kubernetes 中部署 Zabbix
  10. 机器学习基础算法10-回归
  11. 锐捷校园网环境下设置统信UOS(Linux)自动连接网络
  12. 你需要知道的物联网开放平台
  13. 微信小程序的快捷注释
  14. 大疆御air2怎么看经纬度_人人都能拍大片的无人机 – 大疆御 Mavic Air 2 评测
  15. 上升时间测量与示波器带宽
  16. QModelIndex/Role/Model介紹 二
  17. igraph 利用节点列表输出子图并存储
  18. 加密算法学习(一、中、1)——传统加密算法(playfair密码)
  19. soot基础 -- 相关数据结构SootClass,SootMethod,SootBody,Unit的进一步说明
  20. L2-032 彩虹瓶

热门文章

  1. STL 二分查找 upper_bound和lower_bound用法
  2. 动态库与静态库优缺点比较(转 侵删)
  3. openstack--1--基础环境搭建
  4. TypeScript 素描 - 模块解析、声明合并
  5. 对datatable进行linq过滤
  6. kaliBT安装好之后无法上网或者无法获得内网IP
  7. Delphi10 安装Graphics32
  8. Netty 源码走读
  9. APL开发日志--2012-11-18
  10. Delphi写的等待进程运行结束函数