PHP 冒泡排序

冒泡排序

原理:对一组数据,比较相邻数据的大小,将值小数据在前面,值大的数据放在后面。 (以下都是升序排列,即从小到大排列)

举例说明: $arr = array(6, 3, 8, 2, 9, 1);

$arr 有6个数据,按照两两比较大小如下,注意 比较轮数 和 每轮比较次数

 第一轮排序:

    第一次比较  6和3比较 结果:3    6   8   2   9   1     

    第二次比较  6和3比较 结果:3    6   8   2   9   1 

    第三次比较  8和2比较 结果:3    6   2   8   9   1 

    第四次比较  8和9比较 结果:3    6   2   8   9   1 

    第五次比较  9和1比较 结果:3    6   2   8   1   9 

  第一轮比较总结:1.排序第1轮、比较5次,没有获得从小到大的排序   
  				2.因为每次比较都是大数往后靠,所以比较完成后,可以确定大数排在最后
  				(9 已经冒泡冒出来了,下轮比较可以不用比较了 )

 

  第二轮排序:

    第一次比较  3和6比较 结果:3    6   2   8   1   9     

    第二次比较  6和2比较 结果:3    2   6   8   1   9 

    第三次比较  6和8比较 结果:3    2   6   8   1   9 

    第四次比较  8和1比较 结果:3    2   6   1   8   9 

 

  第二轮比较总结:1.排序第2轮、比较4次,没有获得从小到大的排序   
  				2.冒泡出了 8,下轮不用比较8 了

  

  第三轮排序:

    第一次比较  3和2比较 结果:2    3   6   1   8   9     

    第二次比较  3和6比较 结果:2    3   6   1   8   9 

    第三次比较  6和1比较 结果:2    3   1   6   8   9 

  第三轮比较总结:1.排序第3轮、比较3次,没有获得从小到大的排序 
  				 2.冒泡出了 6,下轮不用比较6 了

 

  第四轮排序:

    第一次比较  2和3比较 结果:2    3   1   6   8   9     

    第二次比较  3和1比较 结果:2    1   3   6   8   9 

  第四轮比较总结:1.排序第4轮、比较2次,没有获得从小到大的排序 
  				 2.冒泡出了
  				 3,下轮不用比较3 了

 

  第五轮排序:

    第一次比较  2和1比较 结果:1   2   3   6   8   9


  	 第五轮比较总结:1.排序第5轮、比较1次,没有获得从小到大的排序 
  	 			  2.冒泡出了 2,由于还剩一个1,不用再比较了,至此通过5轮排序,完成整个排序。

通过以上五轮排序,若干次比较,我们有理由推断出一个结论

对于一个长度为N的数组,我们需要排序 N-1 轮,每 i 轮 要比较 N-i 次。对此我们可以用双重循环语句,外层循环控制循环轮次,内层循环控制每轮的比较次数。

例:



<?php

// 定义一个随机的数组
$a = array(23,15,43,25,54,2,6,82,11,5,21,32,65);

// 第一层可以理解为从数组中键为0开始循环到最后一个
for ($i = 0; $i < count($a) ; $i++) {
  // 第二层为从$i+1的地方循环到数组最后
    for ($j = $i+1; $j < count($a); $j++) {
     // 比较数组中两个相邻值的大小
        if ($a[$i] > $a[$j]) {
            $tem = $a[$i]; // 这里临时变量,存贮$i的值
            $a[$i] = $a[$j]; // 第一次更换位置
            $a[$j] = $tem; // 完成位置互换
        }
    }        
}

echo '<pre>';
var_dump($a);
echo '</pre>';
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值