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

一、插入排序

用文字简单的描述,比如说$arr = array(4,2,4,6,3,6,1,7,9); 这样的一组数字进行顺序排序:

那么,首先,拿数组的第二个元素和第一元素比较,假如第一个元素大于第二元素,那么就让两者位置互换,接下来,拿数组的第三个元素,分别和第二个,第一个元素比较,假如第三个元素小,那么就互换。依次类推。这就是插入排序,它的时间频度是:1+2+...+(n-1)=(n^2)/2。则它的时间复杂度为O(n^2).

php实现代码如下:

function insertSort($arr){

$count = count($arr);

if($count<2){

return $arr;

}

for($i=1;$i

$tmp = $arr[$i];

$j=$i-1;

while(j>=0&&$arr[$j]

$arr[$i] = $arr[$j];

$arr[$j] = $tmp;

$j--;

}

}

return $arr;

}

?>

二、选择排序

选择排序用语言描述的话,可以这样,如:$arr = array(4,3,5,2,1);

首先,拿第一个和后面所有的比,找出最小的那个数字,然后和第一个数组互换(当然,如果是第一个最小,那么就不用互换了),接着循环,即:拿第二个和后面的比较,找出最小的数字,然后和第二个数字互换,依次类推,也就是说每次都是找出剩余最小的值。 可得到:第一次,时间频度 是n, (第一个和后面的n-1个比较,找到最小的,再看是不是第一个,不是第一个的话进行互换) 在往后,依次是 减一 。 它的时间复杂度,也是O(n^2);

php实现代码如下:

function selectSort($arr){

$count = count($arr);

if($count<2){

return $arr;

}

for($i=0;$i

$min=$i;

for(j=$i+1;$j

if($arr[$min]>$arr[$j]){

$min = $j; //找到最小的那个元素的下标

}

}

if($min!=$i){//如果下标不是$i 则互换。

$tmp= $arr[$i];

$arr[$i] = $arr[$min];

$arr[$min] = $tmp;

}

}

return $arr;

}

?>

三、冒泡排序

冒泡排序其实上是和选择排序相比,并无明显差别。都是找到最小的,放到最左端。依次循环解决问题。差别在于冒泡排序的交换位置的次数较多,而选择排序则是找到最小的元素的下标,然后直接和最左端的交换位置。

php实现代码如下:

function selectSort($arr){

$count = count($arr);

if($count<2){

return $arr;

}

for($i=0;$i

for(j=$i+1;$j

if($arr[$i]>$arr[$j]){

$tmp= $arr[$i];

$arr[$i] = $arr[$i];

$arr[$i] = $tmp;

}

}

}

return $arr;

}

?>

四、快速排序

快速排序,用语言来形容的话,从数组中选择一个值$a,然后和其余元素进行比较,比$a大的放到数组right中,反之,放到数组left中。然后将left right 分别进行递归调用,即:再细分left right ,最后进行数组的合并。

php实现快速排序:

function mySort($arr){

$count = count($arr);

if($count<2){

return $arr;

}

$key = $arr[0];//选择第一个元素作为比较元素,可选其他

$left = array();

$right = array();

for($i=1;$i

if($key>=$arr[$i]){

$left[] = $arr[$i];

}else{

$right[] = $arr[$i];

}

}

$left = mySort($left);

$right = mySort($right);

$result = array_merge($left,$right);

return $result;

}

?>

五、归并排序

其实归并排序是一种拆分,合并的思想。和快速排序思想有共通之处,左边一堆,右边一堆,然后进行合并。通过递归实现排序。 区别之处呢?  他们的区别也是思想上本质的区别,快速排序的拆分,是选择了特定的值进行大小比较,从而分为left 和 right 。也就是小的一堆放入left,大的一堆放入right。而后,小的left 再细分为left1  right1。。。。通过进行类似的递归完成排序。也就是说,一直细分下去,递归最末尾的left1就是最小值。

而归并排序,是从几何上的左右切分,一直递归切分成2或者1的最小粒度的数组,然后才开始进行比较大小,然后合并。此处的比较大小是:儿子left的元素 和儿子的right元素 进行比较,而后进行排序合并成为父亲left或者right。在此,直到拿到各自排序合并完成最后两个数组:最起初的left 和right,也仅仅直到他们各自的顺序,并不能确认整个数组的顺序,还是需要通过最终的left right 比较后合并才能完成真正意义上的排序。

function gbSort($arr){

if(count($arr)<=1){return $arr;}

$min = floor(count($arr)/2);//取中间数字进行拆分

$left = array_slice($arr,0,$min);

$right = array_slice($arr,$min);

$left = gbSort($left); //递归

$right = gbSort($right);

return get_merge($left,$right);//调用排序合并函数进行合并

}

function get_merge($left,$right){

while(count($left) && count($right)){

$m[] = $left[0]>$right[0] ? array_shift($right) : array_shift($left);

//进行比较,小的移除,并且放入到数组$m中。

}

return arr_merge($m,$left,$right);//进行合并(由于不知道left right 哪个会为空,所以进行统一合并)

}

?>

六、堆排序

本例中fixDown函数实现对某一个节点的向下调整,这里默认的是起始节点为1,方便计算父子节点关系

注:

起始节点为1的父子关系: 父节点k, 子节点为2K、2k+1     子节点j, 父节点为 floor(j/2)  floor为向下取整

起始节点为0的父子关系: 父节点k, 子节点为2K+1, 2k+2   子节点j, 父节点为 floor((j-1)/2)

参数$k为调整点位置, $lenth为数组长度,也就是从1起始到最后一个节点的坐标.

function fixDown(&$arr, $k, $lenth)

{

while(2*$k<=$lenth) { //只要当前节点有子节点, 就需要继续该循环

$j = $k*2;

if ($j

if ($arr[$j] < $arr[$k]) break; // 如果子节点都没有父节点大, 那么调整结束。

exch($arr[$j], $arr[$k]);

$k = $j;

}

}

function exch(&$a, &$b) {

$tmp = $a; $a = $b; $b = $tmp;

}

function headSort(&$arr)

{

$len = count($arr);

array_unshift($arr, NULL);

for($i=$len/2;$i>=1;$i--) {

fixDown($arr, $i, $len);

}

while($len>1) {

exch($arr[1], $arr[$len]);

fixDown($arr, 1, --$len);

}

array_shift($arr);

}

$arr = array(4,6,4,9,2,3);

headSort($arr);

?>

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

php文章排序,php实现的常见排序算法汇总相关推荐

  1. 别说我不懂排序!几种常见排序算法(一)

    part1:冒泡排序 冒泡排序的核心:一步一步交换相邻位置的数据! 代码示例 for 循环实现. def bubble_sort1(arr):# 交换的细节def swap(i,j):arr[i],a ...

  2. 开发中常见的算法汇总之-基数排序

    #### 基数排序 - 核心思想 - 基于桶排序模式,选择一定的桶数量,对待排序数据进行按位数先分割,从低位向高位依次进行轮流入桶出桶操作排序 - 基于**分治算法思想**,对元素进行分配至对应的桶中 ...

  3. java二分排序法原理_Java常见排序算法详解—— 二分插入排序

    转载请注明出处: 二分插入排序Binary Insert Sort 概念: 二分(折半)插入排序是一种在直接插入排序算法上进行小改动的排序算法.其与直接排序算法最大的区别在于查找插入位置时使用的是二分 ...

  4. moead算法流程步骤_数据聚类(一)常见聚类算法的基本原理[图解]

    文章整理了五种常见聚类算法的基本原理,通过简易图解的形式对算法原理进行形象化的描述,同时给出了算法的实现流程和数学表达.全文约4192字. 相关名词的英文翻译 监督学习Supervised Learn ...

  5. python常见排序算法解析

    python--常见排序算法解析 算法是程序员的灵魂. 下面的博文是我整理的感觉还不错的算法实现 原理的理解是最重要的,我会常回来看看,并坚持每天刷leetcode 本篇主要实现九(八)大排序算法,分 ...

  6. 十种常见排序算法欢聚一堂

    文章目录 1.常见排序算法分类 2.非线性时间比较类排序 2.1 交换类排序 2.1.1 冒泡排序 2.1.2 快速排序 2.2 插入类排序 2.2.1 直接插入排序 2.2.2 Shell 排序 2 ...

  7. ++代码实现 感知机的原理_常见排序算法原理及JS代码实现

    来源:SegmentFault 思否社区 作者:Warren 本文只是将作者学习的过程以及算法理解进行简单的分享,提供多一个角度的理解说明,或许让你的困惑能得以解决(代码或说明若有问题,欢迎留言.联系 ...

  8. linux环境下使用sort命令完成常见排序操作

    文章目录 前言 命令作用 常见选项 数据文件 核心参数 用法展示 按照指定列排序 将排序结果存入指定文件 查看文件是否已经排序好 去掉排序结果中的重复行 按照数值结果进行排序 反向排序 自定义分割字符 ...

  9. 常见排序算法(C语言实现)

    常见排序算法(C语言实现) 文章目录 常见排序算法(C语言实现) 一.插入排序 二.希尔排序 三.选择排序 四.堆排序 五.冒泡排序 六.快速排序 七.归并排序 一.插入排序 void insertS ...

  10. js实现常见排序算法

    文章目录 前言 一.排序相关概念 1.比较排序和非比较排序 比较排序 非比较排序 2.稳定性和不稳定性 二.各排序算法对比 三.排序算法中的通用函数以及对数器 1.通用函数 交换函数 取两索引的中间下 ...

最新文章

  1. JavaScript 电话手机号码正则表达式
  2. 微博粉丝精灵_腾讯与精灵宝可梦公司宣布合作开发新游戏
  3. Linux下服务器搭建(5)——CentOS下Redis的安装
  4. mysql count 排序_MySQL什么时候会使用内部临时表?
  5. 百度竞价初学者怎样才能建立一个好的思路
  6. sed命令在文件头部插入文本---BSD和GNU版本通用写法
  7. PHP学习笔记【1】--初识php
  8. js获取浏览器和设备相关width(屏幕的宽度)
  9. 检测网络变化(wifi、2g、3g、4g)
  10. Ubuntu18.04无法连接向日葵服务器的问题及解决
  11. 38.线程交换与线程移动
  12. Makefile.am编写规则
  13. 自己设计过App的数据库框架?还是只是停留在使用ormlite greenDao这类框架,一篇文章帮你解答...
  14. w ndows10怎么关闭启动项,Windows10系统移除启动项无用项目的三种方法
  15. 微信小程序 条码 二维码生成
  16. STM32 TIM高级定时器死区时间的计算
  17. 学习以太坊部署智能合约(小插曲) — 执行truffle unbox react报错
  18. 前端初学,记下标签以后参考
  19. Bootstrap 教程第四课:制作一组功能图标按钮
  20. Cesium 基础知识和文档记录

热门文章

  1. 积分形式的詹森不等式_詹森不等式
  2. arcgis 实验教程 第二章 ArcCatalog 简单操作--创建自己独特的工具箱
  3. matlab 如何查数据类型,MATLAB数据类型
  4. 如何用python编写财务记账软件_python实现日常记账本小程序
  5. 用3DMAX制作《滚动的小球》
  6. java给pdf加水印_java pdf添加水印
  7. 傅里叶变换:不只是多项式乘法
  8. workbench动力学周炬_ANSYS Workbench有限元分析实例详解 动力学 周炬 苏金英 ANSYS Workbench动力学数值模拟模态分析教程 有限元理论和工程实践书...
  9. python 模拟鼠标键盘_如何用 python 模拟鼠标和键盘的操作
  10. Ios 12 linux,iOS12.3~12.4.2支持越狱?包括 A12 设备