-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathsort.go
93 lines (81 loc) · 2.22 KB
/
sort.go
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
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
package algorithm
type SortObj struct {
List []int
}
/*
QuicklySort 快排:分治的思想
1、选择列表的第一个元素为基准
2、头尾指针移动遍历列表
3、尾指针元素 比 基准小,则对换位置,前移尾指针
4、头指针 比 头指针的后一个元素大,则对换位置,后移头指针
5、递归,重复1、2,排序基准左边、右边的子了列表
时间复杂度:O(nlogn),最大O(n^2)
空间复杂度:递归深度,O(logn),最大O(n)
参考
https://learnku.com/articles/45802
*/
func (s *SortObj) QuicklySort() {
if len(s.List) < 2 {
return
}
l, r := 0, len(s.List)-1
bValue := s.List[l] // 基准
for l < r {
if s.List[r] < bValue { // 尾指针元素 比 基准小,则对换位置,前移尾指针
s.List[l], s.List[r] = s.List[r], s.List[l]
r--
} else if s.List[l] > s.List[l+1] { // 头指针 比 头指针的后一个元素大,则对换位置,后移头指针
s.List[l], s.List[l+1] = s.List[l+1], s.List[l]
l++
} else {
l++
}
}
subLList := new(SortObj)
subLList.List = s.List[:l]
subLList.QuicklySort()
subLRList := new(SortObj)
subLRList.List = s.List[l+1:]
subLRList.QuicklySort()
}
/*
BubbleSort 冒泡排序
时间复杂度:O(n2)
思路
1、依次比较相邻的俩个数,交换大的数到后面,一轮后,最大的数在最右边
2、重复1的,遍历比较除最右边元素外的其他数
*/
func BubbleSort(ls []int) {
l := len(ls)
if l < 1 {
return
}
for i := 0; i < l; i++ {
for j := 0; j < l-i-1; j++ { // 遍历比较除最右边已排序元素外的其他数
if ls[j+1] < ls[j] {
ls[j], ls[j+1] = ls[j+1], ls[j] // 交换大的元素到右侧
}
}
}
}
// =====================
/*
选择排序:剩下的元素,假定第一个为最小,遍历,找到最小,与剩下元素的第一个交换
时间复杂度:O(n2)
思路
1、假定剩下元素的第一个未最小
2、依次遍历剩下元素,若有比它小的,则交换位置
*/
func SelectSort(ls []int) {
l := len(ls)
if l < 1 {
return
}
for i := 0; i < len(ls); i++ {
for j := i + 1; j < l; j++ { // 遍历右侧剩下的元素
if ls[i] > ls[j] {
ls[j], ls[i] = ls[i], ls[j] // 交换最小的元素到第一个位置
}
}
}
}