小编 · 7月13日 · 2020年
冒泡排序 | 平均 | 最好 | 最坏 | 辅助空间 | 稳定性 |
---|
时间复杂度 | O(n^2) | O(n) | O(n^2) | O(1) | 稳定 |
<?php
$arr = [5, 2, 9, 21, 2, 56, 34, 12, 90, 45];
$len = count($arr);
for($i = 0; $i < $len; $i++) {
for($j = 0; $j < $len - 1 - $i; $j++) {
if($arr[$j] > $arr[$j+1]) {
list($arr[$j+1], $arr[$j]) = [$arr[$j], $arr[$j+1]];
}
}
}
print_r($arr);
简单选择排序 | 平均 | 最好 | 最坏 | 辅助空间 | 稳定性 |
---|
时间复杂度 | O(n^2) | O(n^2) | O(n^2) | O(1) | 不稳定 |
<?php
$arr = [5, 2, 9, 21, 2, 56, 34, 12, 90, 45];
$len = count($arr);
for($i = 0; $i < $len - 1; $i++) {
$min = $i;
for($j = $i + 1; $j < $len; $j++) {
if($arr[$j] < $arr[$min]) {
$min = $j;
}
}
if($min !== $i) {
list($arr[$min], $arr[$i]) = [$arr[$i], $arr[$min]];
}
}
print_r($arr);
直接插入排序 | 平均 | 最好 | 最坏 | 辅助空间 | 稳定性 |
---|
时间复杂度 | O(n^2) | O(n) | O(n^2) | O(1) | 稳定 |
<?php
$arr = [5, 2, 9, 21, 2, 56, 34, 12, 90, 45];
$len = count($arr);
for($i = 0; $i < $len - 1; $i++) {
for($j = $i + 1; $j > 0; $j--) {
if($arr[$j] < $arr[$j - 1]) {
list($arr[$j], $arr[$j - 1]) = [$arr[$j - 1], $arr[$j]];
}
}
}
print_r($arr);
必须 注册 为本站用户, 登录 后才可以发表评论!