PHP 冒泡排序

本文详细介绍了冒泡排序算法的工作原理及实现过程。通过对一个具体数组的排序实例进行逐步解析,展示了如何通过比较相邻元素并交换位置来实现升序排列。最终得出冒泡排序的核心思想:对长度为N的数组需进行N-1轮排序,每轮需比较N-i次。

冒泡排序

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

举例说明: $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>';
物联网通信协议测试是保障各类设备间实现可靠数据交互的核心环节。在众多适用于物联网的通信协议中,MQTT(消息队列遥测传输)以其设计简洁与低能耗的优势,获得了广泛应用。为确保MQTT客户端与服务端的实现严格遵循既定标准,并具备良好的互操作性,实施系统化的测试验证至关重要。 为此,采用TTCN-3(树表结合表示法第3版)这一国际标准化测试语言构建的自动化测试框架被引入。该语言擅长表达复杂的测试逻辑与数据结构,同时保持了代码的清晰度与可维护性。基于此框架开发的MQTT协议一致性验证套件,旨在自动化地检验MQTT实现是否完全符合协议规范,并验证其与Eclipse基金会及欧洲电信标准化协会(ETSI)所发布的相关标准的兼容性。这两个组织在物联网通信领域具有广泛影响力,其标准常被视为行业重要参考。 MQTT协议本身存在多个迭代版本,例如3.1、3.1.1以及功能更为丰富的5.0版。一套完备的测试工具必须能够覆盖对这些不同版本的验证,以确保基于各版本开发的设备与应用均能满足一致的质量与可靠性要求,这对于物联网生态的长期稳定运行具有基础性意义。 本资源包内包含核心测试框架文件、一份概述性介绍文档以及一份附加资源文档。这些材料共同提供了关于测试套件功能、应用方法及可能包含的扩展工具或示例的详细信息,旨在协助用户快速理解并部署该测试解决方案。 综上所述,一个基于TTCN-3的高效自动化测试框架,为执行全面、标准的MQTT协议一致性验证提供了理想的技术路径。通过此类专业测试套件,开发人员能够有效确保其MQTT实现的规范符合性与系统兼容性,从而为构建稳定、安全的物联网通信环境奠定坚实基础。 资源来源于网络分享,仅用于学习交流使用,请勿用于商业,如有侵权请联系我删除!
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值