php冒泡排序从小到大的操作
2023-03-20 14:44:51 时间
我们在了解了基础的冒泡排序后,根据它的原理可以看出,是非常适合处理一些从小到大的排序问题的。不过很多人只对原理有一个大致接触,在具体的实现步骤上不知道如何下手。本篇我们就冒泡排序的基本思想、排序步骤分析带来全面的介绍,然后为大家提供一个新的冒泡排序实例进行练手。
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数组
相关文章
- 金融服务领域的大数据:即时分析
- 影响大数据、机器学习和人工智能未来发展的8个因素
- 从0开始构建一个属于你自己的PHP框架
- 如何将Hadoop集成到工作流程中?这6个优秀实践必看
- SEO公司使用大数据优化其模型的5种方法
- 关于Web Workers你需要了解的七件事
- 深入理解HTTPS原理、过程与实践
- 增强分析:数据和分析的未来
- PHP协程实现过程详解
- AI专家:大数据知识图谱——实战经验总结
- 关于PHP的错误机制总结
- 利用数据分析量化协同过滤算法的两大常见难题
- 怎么做大数据工作流调度系统?大厂架构师一语点破!
- 2019大数据处理必备的十大工具,从Linux到架构师必修
- OpenCV中的KMeans算法介绍与应用
- 教大家如果搭建一套phpstorm+wamp+xdebug调试PHP的环境
- CentOS下三种PHP拓展安装方法
- Go语言HTTP Server源码分析
- Go语言HTTP Server源码分析
- 2017年4月编程语言排行榜:Hack首次进入前五十