• 技术文章 >头条 >PHP

    php冒泡排序从小到大的操作

    小妮浅浅小妮浅浅2021-02-08 17:26:49原创16143

    我们在了解了基础的冒泡排序后,根据它的原理可以看出,是非常适合处理一些从小到大的排序问题的。不过很多人只对原理有一个大致接触,在具体的实现步骤上不知道如何下手。本篇我们就冒泡排序的基本思想、排序步骤分析带来全面的介绍,然后为大家提供一个新的冒泡排序实例进行练手。

    1.基本思想

    冒泡排序是一种交换排序,它的基本思想是:两两比较相邻记录的关键字,如果反序则交换,直到没有反序的记录为止。

    2.排序步骤分析

    $ars = [4,3,5,9,6,2];

    这是一个有6个元素的数组,那么开始使用冒泡排序,首先理解下冒泡排序,原理简单说明就是:两两比较,值大的往后放

    第一次:数组的第一个元素跟第二个元素比较,4>3,所以,4要往后放 [3,4,5,9,6,2]

    第二次:数组的第二个元素(这时候已经是4了,不是3了)跟第三个元素比较,4<5,不动 [3,4,5,9,6,2]

    第三次:数组的第三个元素跟第四个元素比较,5<9,不动 [3,4,5,9,6,2]

    第四次:数组的第四个元素跟第五个元素比较,9>6,9要往后放 [3,4,5,6,9,2]

    第五次:数组的第五个元素跟第六个元素比较,9>2,9要往后放 [3,4,5,6,2,9]

    第六次:第六个元素没有比较对象,所以结束了(很多人迷惑为什么代码是那样写的,问题可能就在这里)

    5次比较下来,只得到一个9在最后面,那么就需要循环来遍历不断的进行第二轮的比较

    3.实例

    <?php
     
    //定义一个数组
     
    $arr=[2,1,4,5,56,7,17,22];
     
    //获取数组元素个数
     
    $count=count($arr);
     
    //遍历数组并排序
     
    for($i=0;$i<$count;$i++){//控制循环次数为$count-1次
     
            //假设最右边的元素
     
            for($j=0;$j<$count-1;$j++){
                        //如果前面的元素比相邻后面元素大两者就交换位置
     
                        if($arr[$j+1]<$arr[$j]){
                                   $tem=$arr[$j+1];
     
                                    $arr[$j+1]=$arr[$j];
     
                                    $arr[$j]=$tem;
     
                 }
     
            }
     
    }
     
    echo "<pre/>";
     
    var_dump($arr);

    以上就是php冒泡排序从小到大的方法,相信经过全面的排序步骤讲解,大家已经学会了冒泡排序在实际中的操作了。学会后可以就本篇的新代码实例,进行一次独立的排序尝试。更多php学习指路:php数组

    专题推荐:php冒泡排序从小到大
    上一篇:php冒泡排序是什么意思 下一篇:php选择排序是什么

    相关文章推荐

    • php索引数组有什么用?• php之laravel调度执行及出错解决• 如何在php中创建字符串的变量?• PHP索引数组的优点分析• php数组排序函数• php冒泡排序是什么意思

    全部评论我要评论

    © 2021 Python学习网 苏ICP备2021003149号-1

  • 取消发布评论
  • 

    Python学习网