-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathinversions.go
74 lines (60 loc) · 1.3 KB
/
inversions.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
package main
import "fmt"
import "os"
import "io"
import "bufio"
import "strconv"
// Input data is in IntegerArray.txt
func main() {
arr := make([]int, 0)
reader := bufio.NewReader(os.Stdin)
func() error {
for {
switch line, _, err := reader.ReadLine(); err {
case nil:
item, e := strconv.Atoi(string(line))
if e == nil {
arr = append(arr, item)
}
case io.EOF:
return nil
default:
return err
}
}
return nil
}()
fmt.Println("Input array contains", len(arr), "items")
inv, _ := get_invertions(arr)
fmt.Println("Inversion count:", inv)
}
func get_invertions(array []int) (uint, []int) {
al := len(array)
if al == 0 {
return 0, array
}
if al > 1 {
med := al / 2
linv, left := get_invertions(array[:med])
rinv, right := get_invertions(array[med:])
return compute_inverts(left, right, linv+rinv)
}
return 0, []int{array[0]}
}
func compute_inverts(left, right []int, inv uint) (uint, []int) {
var i, j, ll, rl = uint(0), uint(0), uint(len(left)), uint(len(right))
res := make([]int, 0)
for i < ll && j < rl {
if left[i] < right[j] {
res = append(res, left[i])
i++
} else if right[j] < left[i] {
res = append(res, right[j])
j++
inv += ll - i
}
}
res = append(res, left[i:]...)
res = append(res, right[j:]...)
return inv, res
}