# 插入排序(数组排序)
## 定义:
> 我们将数组中的数据分为两个区间,已排序区间和未排序区间。初始已排序区间只有一个元素,就是数组的第一个元素。插入算法的核心思想是取未排序区间中的元素,在已排序区间中找到合适的插入位置将其插入,并保证已排序区间数据一直有序。重复这个过程,直到未排序区间中元素为空,算法结束。
![](https://box.kancloud.cn/08d160492ea2236b155598eb86aa662f_1142x744.png)
## 代码:
~~~
/**
* @param $nums
* @return mixed
* 4 3 2 1
*/
function insert_sort($nums){
if(count($nums) <= 1){
return $nums;
}
for($i=1;$i<count($nums);$i++){//控制最大循环次数
$value = $nums[$i];//记录下当前需要比较的元素的值
for($j=$i-1;$j>=0;$j--){//拿$value值与已排序区的每个值比较,如果大于$value就后移一位
if($nums[$j] > $value){
$nums[$j+1] = $nums[$j];
}else{
break;
}
}
$nums[$j+1] = $value;//把最后一个后移的值替换成为$value,这样一次循环就完成了
}
return $nums;
}
$nums = [4,3,1,2];
print_r(insert_sort($nums));
~~~
## 插入排序的性能和稳定性
1. 时间复杂度: O(n^2) (n的平方)
2. 空间复杂度:没有额外的存储空间,是原地排序算法
3. 算法稳定性:元素相等不会交换,是稳定的排序算法
## 总结
> 插入排序的时间复杂度和冒泡排序一样,也不是很理想,但是插入排序不涉及数据交换,从更细粒度来区分,性能要略优于冒泡排序。
>
- 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链式操作的实现
- 面向对象编程的基本原则
- 设计模式
- 基本的设计模式