首先在未排序序列中找到最小(大)元素,存放到排序序列的起始位置,然后,再从剩余未排序元素中继续寻找最小(大)元素,然后放到已排序序列的末尾。以此类推,直到所有元素均排序完毕。
算法描述
- 首先在未排序序列中找到最小(大)元素,存放到排序序列的起始位置;
- 再从剩余未排序元素中继续寻找最小(大)元素,然后放到已排序序列的末尾;
- 重复第二步,直到所有元素均排序完毕。
动图演示

代码实现
<?phpclass Sorting{/*** 选择排序(不稳定地原地排序算法)** @param array $array* @return array*/public function selectionSort(array $array): array{$length = count($array);for ($i = 0; $i < $length - 1; $i++) {$minIndex = $i;for ($j = $i + 1; $j < $length; $j++) {if ($array[$j] < $array[$minIndex]) {$minIndex = $j;}}$temp = $array[$i];$array[$i] = $array[$minIndex];$array[$minIndex] = $temp;}return $array;}}
算法分析
- 时间复杂度:O(n2)
- 空间复杂度:O(1)
- 非稳定排序
- 原地排序
