summaryrefslogtreecommitdiff
path: root/sort/merge.go
blob: 66a7fd61c8454b0a3e69a8a4f017967945effa52 (plain)
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
package sort

import (
	"codeberg.org/snonux/algorithms/ds"
)

func Merge[V ds.Number](a ds.ArrayList[V]) ds.ArrayList[V] {
	aux := make(ds.ArrayList[V], len(a))
	mergeSort(a, aux)

	return a
}

func mergeSort[V ds.Number](a, aux ds.ArrayList[V]) {
	l := len(a)
	if l <= 10 {
		Insertion(a)
		return
	}

	mi := l / 2
	mergeSort(a[0:mi], aux[0:mi])
	mergeSort(a[mi:], aux[mi:])
	merge(a, aux, 0, mi, l-1)
}

func merge[V ds.Number](a, aux ds.ArrayList[V], lo, mi, hi int) {
	for i := lo; i <= hi; i++ {
		aux[i] = a[i]
	}

	i := lo
	j := mi

	for k := lo; k <= hi; k++ {
		switch {
		case i >= mi:
			a[k] = aux[j]
			j++
		case j > hi:
			a[k] = aux[i]
			i++
		case aux[i] > aux[j]:
			a[k] = aux[j]
			j++
		default:
			a[k] = aux[i]
			i++
		}
	}
}