# 冒泡排序
## 定义:
> 冒泡排序只会操作相邻的两个数据。每次冒泡操作都会对相邻的两个元素进行比较,看是否满足大小关系要求,如果不满足就让它俩互换。一次冒泡会让至少一个元素移动到它应该在的位置,重复 n 次,就完成了 n 个数据的排序工作。
第一次排序流程:
![](https://box.kancloud.cn/8aa33e66e635c5710ad5e227b3a9dc63_1142x741.png)
所谓冒泡,以升序来看,就是每次把待排序序列中的最大值插到已排序序列的最前面,这个过程就像冒泡一样:
![](https://box.kancloud.cn/46520db33e76bc0eaf56715981047af0_1142x749.png)
## 代码实现:
~~~
/**
* @param $nums
* @return mixed
* 4 3 2 1
*/
function bubble_sort($nums){
if(count($nums) <= 1){
return $nums;
}
for($i=0;$i<count($nums);$i++){//控制比较的次数,比较的次数与数组长度有关
$flag = true;//如果为true就表示数组元素位置没有发生改变,用来控制判断数组是否排好了序,这样可以少比较
for($j=0;$j<count($nums)-$i-1;$j++){//控制比较的次数,第一次比较3次,第二次比较2次,第三次比较1次,第四次比较0次
if($nums[$j]>$nums[$j+1]){
$temps = $nums[$j];
$temps[$j] = $nums[$j+1];
$nums[$j+1] = $temps;
$flag = false;
}
}
if($flag){
return $a;
return $nums;
}
}
return $nums;
}
$nums = [1,2,3,4];
print_r(bubble_sort($nums));
~~~
## 冒泡排序的性能和稳定性
1. 时间复杂度: O(n^2) (n的平方)
2. 空间复杂度:只涉及相邻元素的交换,是原地排序算法
3. 算法稳定性:元素相等不会交换,是稳定的排序算法
## 总结:
时间复杂度是 O(n^2),看起来性能并不是很好,所以我们在实践中基本不会选用冒泡算法。
- PHP操作集合
- 获取字符首字母
- PHP实现定时备份MySQL数据库
- PHP定时发送邮件
- PHP基本语法
- 总结
- 命名空间
- 错误抑制符
- 位运算符
- 原码,反码,补码
- traits
- PHP的反射机制
- const和define的区别
- 语法
- 常用的函数
- 1.变量及打印函数
- 2.引入文件
- 3.常量
- 4.错误处理
- 5.面向对象
- 数据结构与算法
- 结构
- 数组
- 索引
- 散列表(哈希表)
- 栈
- 队列
- 链表
- 算法
- 排序算法
- 插入排序
- 冒泡排序
- 选择排序
- 归并排序
- 快速排序
- 查找算法
- 二分查找
- 二分查找变形版本1:查询数据在序列中第一次出现
- 哈希算法
- 算法复杂度
- Smarty模板引擎
- composer
- yaf
- yaf的安装配置
- 其它
- Java
- JavaSE
- 1.Java发展及JDK安装配置
- 2.Eclipse的下载及安装
- 3.Java开发基础
- 虚拟机
- 2.编辑虚拟机设置
- 1.虚拟机下安装centos
- 3.安装vmtools
- Linux
- 1.vi和vim编辑器
- 2.开机、重启和用户登录注销
- 3.用户管理
- 4.用户组管理
- 5.用户和组的相关文件
- 6.linux运行级别
- 7.帮助指令
- 8.文件目录类指令
- 9.时间日期类
- 10.搜索查找类
- 11.压缩和解压缩
- 12.组管理和权限管理(难点,重点)
- 虚拟主机的配置
- phpstudy快捷配置
- 配置文件配置
- PHP面向对象高级特性
- SPL标准库(PHP标准库)
- PHP链式操作的实现
- 面向对象编程的基本原则
- 设计模式
- 基本的设计模式