搜索
首页后端开发php教程php冒泡,选择,插入和快速排序法详解

=分别用 冒泡排序法,快速排序法,选择排序法,插入排序法将下面数组中 的值按照从小到的顺序进行排序。 

$arr(1,43,54,62,21,66,32,78,36,76,39);

1. 冒泡排序法 
 *     思路分析:法如其名,就是像冒泡一样,每次从数组当中 冒一个最大的数出来。 

 *     比如:2,4,1    // 第一次 冒出的泡是4 
 *                2,1,4   // 第二次 冒出的泡是 2 
 *                1,2,4   // 最后就变成这样
$arr=array(1,43,54,62,21,66,32,78,36,76,39);    
function getpao($arr)  
{    
  $len=count($arr);  
  //设置一个空数组 用来接收冒出来的泡  
  //该层循环控制 需要冒泡的轮数  
  for($i=1;$i<$len;$i++)  
  { //该层循环用来控制每轮 冒出一个数 需要比较的次数  
    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;  
        }  
    }  
  }  
  return $arr;  
}
  1. 2. 选择排序法: 



  2. 选择排序法思路: 每次选择一个相应的元素,然后将其放到指定的位置



  1. function select_sort($arr) {  
    //实现思路 双重循环完成,外层控制轮数,当前的最小值。内层 控制的比较次数  
        //$i 当前最小值的位置, 需要参与比较的元素  
        for($i=0; $len=count($arr); $i<$len-1; $i++) {  
            //先假设最小的值的位置  
            $p = $i;  
            //$j 当前都需要和哪些元素比较,$i 后边的。  
            for($j=$i+1; $j<$len; $j++) {  
                //$arr[$p] 是 当前已知的最小值  
                if($arr[$p] > $arr[$j]) {  
         //比较,发现更小的,记录下最小值的位置;并且在下次比较时,  
     // 应该采用已知的最小值进行比较。  
                    $p = $j;  
                }  
            }  
            //已经确定了当前的最小值的位置,保存到$p中。  
     //如果发现 最小值的位置与当前假设的位置$i不同,则位置互换即可  
            if($p != $i) {  
                $tmp = $arr[$p];  
                $arr[$p] = $arr[$i];  
                $arr[$i] = $tmp;  
            }  
        }  
        //返回最终结果  
        return $arr;  
    }


3.插入排序法 

插入排序法思路:将要排序的元素插入到已经 假定排序号的数组的指定位置。

  1. function insert_sort($arr) {  
        //区分 哪部分是已经排序好的  
        //哪部分是没有排序的  
        //找到其中一个需要排序的元素  
        //这个元素 就是从第二个元素开始,到最后一个元素都是这个需要排序的元素  
        //利用循环就可以标志出来  
        //i循环控制 每次需要插入的元素,一旦需要插入的元素控制好了,  
        //间接已经将数组分成了2部分,下标小于当前的(左边的),是排序好的序列  
        for($i=1, $len=count($arr); $i<$len; $i++) {  
            //获得当前需要比较的元素值。  
            $tmp = $arr[$i];  
            //内层循环控制 比较 并 插入  
            for($j=$i-1;$j>=0;$j--) {  
       //$arr[$i];//需要插入的元素; $arr[$j];//需要比较的元素  
                if($tmp < $arr[$j]) {  
                    //发现插入的元素要小,交换位置  
                    //将后边的元素与前面的元素互换  
                    $arr[$j+1] = $arr[$j];  
                    //将前面的数设置为 当前需要交换的数  
                    $arr[$j] = $tmp;  
                } else {  
                    //如果碰到不需要移动的元素  
               //由于是已经排序好是数组,则前面的就不需要再次比较了。  
                    break;  
                }  
            }  
        }  
        //将这个元素 插入到已经排序好的序列内。  
        //返回  
        return $arr;  
    }


4.快速排序法  

  1. function quick_sort($arr) {  
        //先判断是否需要继续进行  
        $length = count($arr);  
        if($length <= 1) {  
            return $arr;  
        }  
        //如果没有返回,说明数组内的元素个数 多余1个,需要排序  
        //选择一个标尺  
        //选择第一个元素  
        $base_num = $arr[0];  
        //遍历 除了标尺外的所有元素,按照大小关系放入两个数组内  
        //初始化两个数组  
        $left_array = array();//小于标尺的  
        $right_array = array();//大于标尺的  
        for($i=1; $i<$length; $i++) {  
            if($base_num > $arr[$i]) {  
                //放入左边数组  
                $left_array[] = $arr[$i];  
            } else {  
                //放入右边  
                $right_array[] = $arr[$i];  
            }  
        }  
        //再分别对 左边 和 右边的数组进行相同的排序处理方式  
        //递归调用这个函数,并记录结果  
        $left_array = quick_sort($left_array);  
        $right_array = quick_sort($right_array);  
        //合并左边 标尺 右边  
        return array_merge($left_array, array($base_num), $right_array);  
    }

以上是php冒泡,选择,插入和快速排序法详解的详细内容。更多信息请关注PHP中文网其他相关文章!

声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
PHP中的依赖注入是什么?PHP中的依赖注入是什么?May 07, 2025 pm 03:09 PM

依赖性注射inphpisadesignpatternthatenhancesFlexibility,可检验性和ManiaginabilybyByByByByByExternalDependencEctenceScoupling.itallowsforloosecoupling,EasiererTestingThroughMocking,andModularDesign,andModularDesign,butquirscarecarefulscarefullsstructoringDovairing voavoidOverOver-Inje

最佳PHP性能优化技术最佳PHP性能优化技术May 07, 2025 pm 03:05 PM

PHP性能优化可以通过以下步骤实现:1)在脚本顶部使用require_once或include_once减少文件加载次数;2)使用预处理语句和批处理减少数据库查询次数;3)配置OPcache进行opcode缓存;4)启用并配置PHP-FPM优化进程管理;5)使用CDN分发静态资源;6)使用Xdebug或Blackfire进行代码性能分析;7)选择高效的数据结构如数组;8)编写模块化代码以优化执行。

PHP性能优化:使用OpCode缓存PHP性能优化:使用OpCode缓存May 07, 2025 pm 02:49 PM

opcodecachingsimplovesphperforvesphpermance bycachingCompiledCode,reducingServerLoadAndResponSetimes.1)itstorescompiledphpcodeinmemory,bypassingparsingparsingparsingandcompiling.2)useopcachebachebachebachebachebachebachebysettingparametersinphametersinphp.ini,likeememeryconmorysmorysmeryplement.33)

PHP依赖注入:增强代码可维护性PHP依赖注入:增强代码可维护性May 07, 2025 pm 02:37 PM

依赖注入在PHP中通过外部注入方式提供对象依赖,提高代码的可维护性和灵活性。其实现方式包括:1.构造函数注入,2.设值注入,3.接口注入,使用依赖注入可以解耦、提高可测试性和灵活性,但需注意可能增加复杂性和性能开销。

如何在PHP中实施依赖注入如何在PHP中实施依赖注入May 07, 2025 pm 02:33 PM

在PHP中实现依赖注入(DI)可以通过手动注入或使用DI容器来完成。1)手动注入通过构造函数传递依赖,如UserService类注入Logger。2)使用DI容器可以自动管理依赖,如Container类管理Logger和UserService。实现DI可以提高代码的灵活性和可测试性,但需要注意过度注入和服务定位器反模式等陷阱。

unset()和session_destroy()有什么区别?unset()和session_destroy()有什么区别?May 04, 2025 am 12:19 AM

Thedifferencebetweenunset()andsession_destroy()isthatunset()clearsspecificsessionvariableswhilekeepingthesessionactive,whereassession_destroy()terminatestheentiresession.1)Useunset()toremovespecificsessionvariableswithoutaffectingthesession'soveralls

在负载平衡的情况下,什么是粘性会话(会话亲和力)?在负载平衡的情况下,什么是粘性会话(会话亲和力)?May 04, 2025 am 12:16 AM

stickysessensureuserRequestSarerOutedTothesMeServerForsessionDataConsisterency.1)sessionIdentificeAssificationAssigeaSsignAssignSignSuserServerServerSustersusiseCookiesorUrlModifications.2)一致的ententRoutingDirectSsssssubsequeSssubsequeSubsequestrequestSameSameserver.3)loadBellankingDisteributesNebutesneNewuserEreNevuseRe.3)

PHP中有哪些不同的会话保存处理程序?PHP中有哪些不同的会话保存处理程序?May 04, 2025 am 12:14 AM

phpoffersvarioussessionsionsavehandlers:1)文件:默认,简单的ButMayBottLeneckonHigh-trafficsites.2)Memcached:高性能,Idealforsforspeed-Criticalapplications.3)REDIS:redis:similartomemememememcached,withddeddeddedpassistence.4)withddeddedpassistence.4)databases:gelifforcontrati forforcontrati,有用

See all articles

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

Video Face Swap

Video Face Swap

使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热工具

WebStorm Mac版

WebStorm Mac版

好用的JavaScript开发工具

SublimeText3 英文版

SublimeText3 英文版

推荐:为Win版本,支持代码提示!

螳螂BT

螳螂BT

Mantis是一个易于部署的基于Web的缺陷跟踪工具,用于帮助产品缺陷跟踪。它需要PHP、MySQL和一个Web服务器。请查看我们的演示和托管服务。

适用于 Eclipse 的 SAP NetWeaver 服务器适配器

适用于 Eclipse 的 SAP NetWeaver 服务器适配器

将Eclipse与SAP NetWeaver应用服务器集成。

Atom编辑器mac版下载

Atom编辑器mac版下载

最流行的的开源编辑器