-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathcode.swift
More file actions
58 lines (47 loc) · 1 KB
/
code.swift
File metadata and controls
58 lines (47 loc) · 1 KB
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
import Foundation
public class ListNode {
public var val: Int
public var next: ListNode?
public init(_ val: Int) {
self.val = val
self.next = nil
}
}
func mergeKLists(_ lists: [ListNode?]) -> ListNode? {
let lists = lists.filter{ $0 != nil}
if lists.count == 0 {
return nil
} else if lists.count == 1 {
return lists.first as? ListNode
}
var array = [Int]()
for list in lists {
var ln = list
while ln != nil {
array.append(ln!.val)
ln = ln!.next
}
}
let rln = ListNode(0)
var ln = rln
for num in array.sorted() {
ln.next = ListNode(num)
ln = ln.next!
}
return rln.next
}
var l1 = ListNode(1)
var l2 = ListNode(4)
var l3 = ListNode(5)
var l4 = ListNode(1)
var l5 = ListNode(3)
var l6 = ListNode(4)
var l7 = ListNode(2)
var l8 = ListNode(6)
l7.next = l8
l5.next = l6
l4.next = l5
l2.next = l3
l1.next = l2
let res = mergeKLists([l1, l4, l7])
print(res!)