forked from wangzheng0822/algo
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathSort.php
67 lines (61 loc) · 1.41 KB
/
Sort.php
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
<?php
// 冒泡排序
function bubbleSort(&$arr)
{
$length = count($arr);
if ($length <= 1) return;
for ($i = 0; $i < $length; $i++) {
$flag = false;
for ($j = 0; $j < $length - $i - 1; $j++) {
if ($arr[$j] > $arr[$j + 1]) {
$tmp = $arr[$j];
$arr[$j] = $arr[$j + 1];
$arr[$j + 1] = $tmp;
$flag = true;
}
}
if (!$flag) {
break;
}
}
}
// 插入排序
function insertionSort(&$arr)
{
$n = count($arr);
if ($n <= 1) return;
for ($i = 1; $i < $n; ++$i) {
$value = $arr[$i];
$j = $i - 1;
// 查找插入的位置
for (; $j >= 0; --$j) {
if ($arr[$j] > $value) {
$arr[$j + 1] = $arr[$j]; // 数据移动
} else {
break;
}
}
$arr[$j + 1] = $value; // 插入数据
}
}
// 选择排序
function selectionSort(&$arr)
{
$length = count($arr);
if ($length <= 1) return;
for ($i = 0; $i < $length - 1; $i++) {
//先假设最小的值的位置
$p = $i;
for ($j = $i + 1; $j < $length; $j++) {
if ($arr[$p] > $arr[$j]) {
$p = $j;
}
}
$tmp = $arr[$p];
$arr[$p] = $arr[$i];
$arr[$i] = $tmp;
}
}
$arr = [1,4,6,2,3,5,4];
insertionSort($arr);
var_dump($arr);