-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathllist-rotatektime.go
104 lines (84 loc) · 1.37 KB
/
llist-rotatektime.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
94
95
96
97
98
99
100
101
102
103
104
package main
import (
"errors"
"fmt"
"math"
)
type list struct {
head *node
}
type node struct {
val int
next *node
}
func main() {
l := &list{}
nums := []int{1, 2, 3, 4, 5}
k := 4
for i := 0; i < len(nums); i++ {
l.Insert(nums[i])
}
l.Show()
l.Rotate(k)
l.Show()
}
func (l *list) Insert(nums int) error {
n := &node{
val: nums,
next: nil,
}
if l.head == nil {
l.head = n
return nil
} else {
curr := l.head
for curr.next != nil {
curr = curr.next
}
curr.next = n
}
return nil
}
func (l *list) Show() {
if l.head == nil {
fmt.Print("empty list")
return
}
curr := l.head
for curr.next != nil {
fmt.Printf("Val: %v\n", curr.val)
curr = curr.next
}
fmt.Printf("Val: %v\n", curr.val)
fmt.Println()
}
func (l *list) Rotate(k int) error {
if l.head == nil {
errors.New("nil list")
}
curr := l.head
head := l.head
ll := 1
for curr.next != nil {
curr = curr.next
ll++
}
if curr.next == nil {
curr.next = head
}
endNode := math.Abs(float64(ll - k%ll))
for endNode > 0 {
curr = curr.next
fmt.Printf("new curr: %v and new curr.next: %v\n", curr.val, curr.next.val)
endNode--
fmt.Printf("endNode: %v\n", endNode)
}
fmt.Println()
temp := curr.next
fmt.Printf("temp: %v\n", temp)
curr.next = nil
fmt.Printf("curr.next: %v\n", curr.next)
l.head = temp
fmt.Printf("l.head: %v\n", l.head)
return nil
}