# 选择排序
## 定义:
> 选择排序算法的实现思路有点类似插入排序,也分已排序区间和未排序区间。但是选择排序每次会从未排序区间中找到最小的元素,将其放到已排序区间的末尾。
![](https://box.kancloud.cn/25e4564b0231dc958d88ccf2b1629ac3_1142x856.png)
## 代码:
```
/**
* @param $nums
* @return mixed
* 4 3 2 1
*/
function selection_sort($nums){
if(count($nums) <= 1){
return $nums;
}
for($i=0;$i<count($nums);$i++){//控制最大循环次数,未排序区的第一个值
$min = $i;//假设最小的数的为未排序区的第一个数
for($j=$i+1;$j<count($nums);$j++){//拿未排序区的每一个值与最小数比较,总是记录最小的数,这样就可以找到未排序区的最小值
if($nums[$j] < $nums[$min]){
$min = $j;
}
}
if($min != $i){//把未排序区的最小值与未排序区第一个数交换位置,也就是把未排序区中的最小值放到已排序区的后面
$temps = $nums[$i];
$nums[$i] = $nums[$min];
$nums[$min] = $temps;
}
}
return $nums;
}
$nums = [4,3,1,2];
print_r(selection_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链式操作的实现
- 面向对象编程的基本原则
- 设计模式
- 基本的设计模式