您的位置:首页 >PHP怎样实现冒泡排序算法_PHP实现冒泡排序算法方法【算法】
发布于2026-05-03 阅读(0)
扫一扫,手机访问
冒泡排序在PHP中可通过三种方式实现:一是双重for循环逐轮比较交换;二是while循环配合标志位优化提前终止;三是封装为支持升序/降序切换的可复用函数。

在PHP开发中,处理一组需要排序的数值是家常便饭。说到排序,冒泡排序虽然效率不算顶尖,但它原理直观,实现起来也简单,是理解排序算法思想的绝佳起点。今天,我们就来聊聊在PHP里实现冒泡排序的几种不同姿势,从最基础的到优化过的,再到封装成工具的,总有一款适合你。
这是教科书式的经典实现,思路非常清晰:外层循环负责控制排序的“轮数”,内层循环则像巡逻兵一样,在每一轮里挨个比较相邻的两个元素,让较大的那个(以升序为例)像气泡一样慢慢“浮”到数组的末尾。
具体怎么操作呢?第一步,你得有一组待排序的数据,比如 $arr = [64, 34, 25, 12, 22, 11, 90]。
接下来,外层循环从第0轮开始,总共需要执行 count($arr) - 1 轮。为什么减一?因为最后一个元素在最后一轮比较后,其位置自然就确定了。
立即学习“PHP免费学习笔记(深入)”;
在每一轮内部,内层循环的遍历范围是关键。它从索引0开始,一直走到 count($arr) - 2 - 当前轮数。这个“- 当前轮数”就是优化点,意味着每一轮过后,数组末尾已经就位的最大元素就不用再参与比较了。
巡逻兵(内层循环)在比较时,如果发现 $arr[j] 大于 $arr[j + 1],那就得让它们交换位置。交换的代码怎么写?可以借助一个临时变量,不过PHP里有个更简洁的写法:list($arr[j], $arr[j + 1]) = [$arr[j + 1], $arr[j]],一行搞定。
当所有轮次都走完,恭喜你,一个升序排列的数组就诞生了。
双重for循环虽然标准,但有个小问题:即使数组在中间某一轮已经排好序了,它还是会傻乎乎地把剩下的轮次跑完。有没有办法让它聪明点,提前收工呢?答案就是引入一个“标志位”。
这个方法的思路很巧妙。首先,初始化两个变量:$swapped = true(表示发生过交换)和 $n = count($arr)(记录数组长度)。
然后,用一个while循环,条件是 $swapped 为真。一进入循环,立刻把 $swapped 设为 false,仿佛在说:“我假设这一轮不会有任何交换了”。
接着,还是用for循环遍历数组,范围是0到 $n - 2。在比较时,如果发现逆序对并进行了交换,就赶紧把 $swapped 标记为 true,意思是:“报告,本轮有交换发生,还不能结束!”
每一轮结束后,别忘了把 $n 减1。这同样是缩小比较范围,因为末尾的元素已经就位了。
当某一轮遍历下来,$swapped 依然是 false 时,while循环的条件就不再满足,循环终止,排序完成。这对于近乎有序的数据来说,效率提升非常明显。
把代码写死在一个地方,每次用都要复制粘贴?这可不是好习惯。更好的做法是把它封装成一个函数,不仅能反复调用,还能自由选择是升序还是降序。
首先,定义函数签名:function bubbleSort(array $arr, bool $ascending = true): array。看,第二个参数 $ascending 默认是 true,代表升序,调用时传 false 就能轻松切换为降序。
函数内部,第一步通常是复制一份输入数组。这是为了避免函数内部的操作意外修改了外部的原始数据,这是一个良好的编程实践。
外层和内层循环的结构和之前类似。关键的区别在于比较条件。这里需要根据 $ascending 参数动态决定:升序时用 >,降序时用 <。这样一来,排序的方向就完全可控了。
交换元素时,依然推荐使用简洁的 list() 语法。最后,函数返回排序后的新数组。调用时,只需传入数组和想要的顺序(true 或 false),清晰又方便。
上面那种封装方式会返回一个新数组,虽然安全,但如果数组很大,复制一份会消耗额外的内存。有没有办法直接在原数组上动手脚,省去复制的开销呢?当然有,那就是使用“引用传递”。
这种方法的函数签名有所不同:function bubbleSortInPlace(array &$arr, bool $ascending = true): void。注意参数 $arr 前面的 & 符号,它意味着函数接收的是原始数组的引用,而不是副本。
既然操作的是原数组,函数自然就不需要返回值了,所以返回类型是 void。
排序逻辑本身和之前大同小异。内层循环的边界可以设为 count($arr) - $i - 1,随着轮次 $i 增加,比较范围逐步缩小。
比较和交换的代码照旧,但所有操作都会直接作用在传入的原始数组 $arr 上。调用这个函数后,你原来的数组就已经被修改了。这里必须敲个黑板:此操作不可逆,如果你之后还需要原数组的数据,请务必提前做好备份。
售后无忧
立即购买>office旗舰店
售后无忧
立即购买>office旗舰店
售后无忧
立即购买>office旗舰店
售后无忧
立即购买>office旗舰店
正版软件
正版软件
正版软件
正版软件
正版软件
1
2
3
7
9