百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术文章 > 正文

「PHP」常用四种排序算法以及性能对比

myzbx 2025-07-02 23:18 24 浏览

作为一名合格的PHPer怎么能不接触到算法这个高大上的东西了,今天就来针对初学者来说一说最基础的4种排序算法:冒泡排序、选择排序、插入排序、快速排序(分区排序)。


冒牌排序

核心思想:比较相邻两个元素的大小,如果左边大于右边,则调换两个元素的位置;

缺点:需要将数组中的每一个元素都进行对比,耗时较长

$array = [5,10,3,4,2,8,7,9,11];
$length = count($array);
//第一层控制循环的次数,元素有多少个就需要循坏多少次
for ($i = 1; $i < $length; $i++) {

    //第二层循环比较相邻元素的大小,调换位置
    for ($j = 0; $j < $length - $i; $j++) {
        if ($array[$j] > $array[$j + 1]) {
            $tmp           = $array[$j + 1];    //临时保存,替换两者位置
            $array[$j + 1] = $array[$j];
            $array[$j]     = $tmp;
        }
    }
}
return $array;

选择排序

核心思想:取后一位元素与当前元素对比,然后将小的元素插入到最前位置

$array = [5,10,3,4,2,8,7,9,11];
$length = count($array);
//第一层控制循环的次数,元素有多少个就需要循坏多少次
    for ($i = 0; $i < $length - 1; $i++) {
        $p = $i;    //假设当前元素是最小元素的下标;
        
        //第二层循环从下一个元素开始比较
        //注意这里的开始位置是从基准元素的下一个位置开始的
        //可以认为前面的元素是已经排序完成了
        for ($j = $i + 1; $j < $length; $j++) {
            //找到更小的元素下标
            if ($array[$p] > $array[$j]) {
                $p = $j;
            }
        }
        
        //如果最小元素不是之前假设的元素,则调换位置
        if ($p != $i) {
            $tmp       = $array[$p];
            $array[$p] = $array[$i];
            $array[$i] = $tmp;
        }
    }
return $array;



插入排序

核心思想:每次循环中,从下一个元素开始比较,然后将最小的元素插入到数组的最前面(但是为了更好的性能,我们通常采用替换位置的方法来将最小元素位移到数组的前面)

$array = [5,10,3,4,2,8,7,9,11];
$length = count($array);
//第一层控制循环的次数,元素有多少个就需要循坏多少次
    for ($i = 1; $i < $length; $i++) {
        $tmp = $array[$i];  //记录当前基准元素

        //从基准元素的下一个元素开始比较
        for ($j = $i - 1; $j >= 0; $j--) {
            
            //如果下一个元素比当前基准元素要小则调换位置            
            if ($tmp < $array[$j]) {
                $array[$j + 1] = $array[$j];
                $array[$j]     = $tmp;
            } else {
                break;
            }
        }

    }
return $array;

快速排序

核心思想:取任意元素为基准,然后二分递归一直执行,每次都是小的左边,大的右边。最后将结果合并

$array = [5,10,3,4,2,8,7,9,11];
//如果不是数组则终止执行
    if (!is_array($array)) return false;
    
    $length = count($array);
    
    //如果数组元素小于2个则终止执行
    if ($length <= 1) return $array;
    
    
    $left = $right = [];
    //任意取一个元素作为基准元素
    //将小于该基准的元素存放进左边
    //将大于该基准的元素存放进右边
    for ($i = 1; $i < $length; $i++) {
        if ($array[$i] > $array[0]) {
            $right[] = $array[$i];
        } else {
            $left[] = $array[$i];
        }
    }

    //递归执行
    $left  = quick_sort($left);
    $right = quick_sort($right);

    //将结果合并
    return array_merge($left, [$array[0]], $right);


最后总结

经测试,四种方法中快速排序的性能最高。数组取10000个元素,然后分别执行消耗的时间如图所示



在实际开发中,能直接使用到这样代码的场景并不多,但是作为程序员缺必须掌握这种开发思想逻辑。如果只是完成了业务开发就万事大吉的话注定后面的路子会越来越难走的。

相关推荐

半导体行业术语缩写词典总结-JKL_半导体词汇缩写表

作为半导体行业新人来说,最痛苦的莫过于各种缩写词术语了,有的缩写词一样但是会有不同的解释。这里作者给大家整理了部分术语词典,后面会按照更新顺序一一分享出来。废话不多说,直接开始,如有遗漏,欢迎大家在评...

JD.com Deepens Push Into Embodied Intelligence With Investment in Sensor Maker PaXiniTech

ToraOne,thesecond-generationmultidimensionaltactilehumanoidrobotdevelopedbyPaXiniTechTMTPOS...

Hong Kong&#39;s Consumer Market Becomes New Battleground for Chinese Mainland Internet Giants

AI-generatedimageTMTPOST--StrollthroughthestreetsofHongKongtoday,anditmightfeellikey...

http2解决了哪些问题_简述http2的优点

HTTP/2(最初称为SPDY)是HTTP协议的第二个主要版本,它在HTTP/1.1的基础上进行了重大改进,旨在解决其在性能和效率方面的诸多瓶颈。以下是HTTP/2主要解决的问题:队头阻...

China&#39;s economy stays strong and vital amid pressure

Peoplevisitthe4thChina-CEECExpo&InternationalConsumerGoodsFairinNingbo,eastChina's...

JD.com Makes $2.4 Billion Bid for Ceconomy in Bold Push to Build a Global Retail Empire

TMTPOST--JD.comhasunveiledplanstoacquireGermany’sCeconomyAG—theparentofEurope’sleading...

深入剖析 Java 中的装饰器设计模式:原理、应用与实践

在Java软件开发的广阔天地里,设计模式犹如璀璨星辰,照亮我们构建高效、可维护系统的道路。今天,让我们聚焦于其中一颗闪耀的星——装饰器设计模式,深入探究它的奥秘,看看如何利用它为我们的代码赋予...

组合模式应用-适配器模式_适配器组件

写在前面Hello,我是易元,这篇文章是我学习设计模式时的笔记和心得体会。如果其中有错误,欢迎大家留言指正!该部分为各模式组合使用,涉及代码较多,熟能生巧。内容回顾定义适配器模式是一种结构型设计模式,...

OOM (Out Of Memory) 故障排查指南

1.确认OOM类型首先需要确认是哪种类型的OOM:JavaHeapOOM:Java堆内存不足NativeMemoryOOM:本地内存不足MetaspaceOOM:元空间内存不足Contai...

刷完这49题,面试官当场给Offer!Java程序员必备指南

1.问题:如果main方法被声明为private会怎样?答案:能正常编译,但运行的时候会提示”main方法不是public的”。2.问题:Java里的传引用和传值的区别是什么?答案:传引用是指传递的是...

C#编程基础(看这一篇就够了)_c#编程入门与应用

C#及其开发环境简介C#概述C#是一个现代的、通用的、面向对象的编程语言,由微软(Microsoft)开发,经Ecma和ISO核准认可。它由AndersHejlsberg和他的团队在.NET框架开发...

说一下JDK的监控和 线上处理的一些case

一句话总结JDK监控常用工具包括JConsole、VisualVM、JMC等,用于实时查看内存、线程、GC状态。线上常见问题处理:内存泄漏通过heapdump分析对象引用链;频繁GC可调整-Xmx/...

JavaScript深拷贝极简指南:3种方法解决嵌套与循环引用难题

为什么需要深拷贝?首先我们看看浅拷贝,point指向的是同一个地址,这时我们修改obj2.point的属性时,obj1的point属性也会被修改再看看深拷贝,point指向的是不同地址,这时我们修改o...

Java 25 在 JEP 519 中集成了紧凑对象头

作者|ANMBazlurRahman译者|刘雅梦策划|丁晓昀Java25通过JEP519将紧凑对象头作为产品特性进行了集成,在不需要更改任何代码的情况下,为开发人员提供了...

每日一练 Python 面试题(1)_python每日一记

以下是5道Python基本语法相关的面试题,涵盖变量、运算符、数据结构、函数和异常处理等核心概念:1.变量与作用域题目:以下代码的输出是什么?解释原因。x=10deffunc():...