-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathmain.swift
130 lines (93 loc) · 3.91 KB
/
main.swift
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
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
//
// main.swift
// LeetCode
//
// Created by Artem Mayer on 26.08.22.
//
import Foundation
final class Solution {
// MARK: - 21. Merge Two Sorted Lists
func mergeTwoSortedLists(_ list1: ListNode?,
_ list2: ListNode?,
alternativeSolution: Bool = false) -> ListNode? {
let solution = MergeTwoSortedLists_Solution()
return alternativeSolution ?
solution.mergeTwoLists_v2(list1, list2) :
solution.mergeTwoLists_v1(list1, list2)
}
// MARK: - 102. Binary Tree Level Order Traversal
func binaryTreeLevelOrderTraversal(_ root: TreeNode?, iterative: Bool = true) -> [[Int]] {
let solution = BinaryTreeLevelOrderTraversal_Solution()
return iterative ? solution.levelOrder_iteratively(root) : solution.levelOrder_recursively(root)
}
// MARK: - 121. Best Time to Buy and Sell Stock
func bestTimeToBuyAndSellStock(_ prices: [Int]) -> Int {
let solution = BestTimeToBuyAndSellStock_Solution()
return solution.maxProfit(prices)
}
// MARK: - 142. Linked List Cycle II
func linkedListCycleII(_ head: ListNode?) -> ListNode? {
let solution = LinkedListCycleII_Solution()
return solution.detectCycle(head)
}
// MARK: - 205. Isomorphic Strings
func isomorphicString(_ s: String, _ t: String, alternativeSolution: Bool = false) -> Bool {
let solution = IsomorphicStrings_Solution()
return alternativeSolution ? solution.isIsomorphic_v2(s, t) : solution.isIsomorphic_v1(s, t)
}
// MARK: - 278. First Bad Version
func firstBadVersion(_ n: Int) -> Int {
let solution = FirstBadVersion_Solution()
return solution.firstBadVersion(n)
}
// MARK: - 409. Longest Palindrome
func longestPalindrome(_ s: String) -> Int {
let solution = LongestPalindrome_Solution()
return solution.longestPalindrome(s)
}
// MARK: - 589. N-ary Tree Preorder Traversal
func treePreorderTraversal(_ root: Node?, iterative: Bool = true) -> [Int] {
let solution = NAryTreePreorderTraversal_Solution()
return iterative ? solution.preorder_iteratively(root) : solution.preorder_recursive(root)
}
// MARK: - 648. Replace Words
func replaceWords(_ dictionary: [String], _ sentence: String) -> String {
let solution = ReplaceWords_Solution()
return solution.replaceWords(dictionary, sentence)
}
// MARK: - 704. Binary Search
func binarySearch(_ nums: [Int], _ target: Int) -> Int {
let solution = BinarySearch_Solution()
return solution.search(nums, target)
}
// MARK: - 849. Maximize Distance to Closest Person
func maximizeDistanceToClosestPerson(_ seats: [Int]) -> Int {
let solution = MaximizeDistanceToClosestPerson_Solution()
return solution.maxDistToClosest(seats)
}
// MARK: - 876. Middle of the Linked List
func middleNodeOfTheLinkedList(_ head: ListNode?) -> ListNode? {
let solution = MiddleOfTheLinkedList_Solution()
return solution.middleNode(head)
}
// MARK: - 949. Largest Time for Given Digits
func largestTimeForGivenDigits(_ arr: [Int]) -> String {
let solution = LargestTimeForGivenDigits_Solution()
return solution.largestTimeFromDigits(arr)
}
// MARK: - 1002. Find Common Characters
func findCommonCharacters(_ words: [String]) -> [String] {
let solution = FindCommonCharacters_Solution()
return solution.commonChars(words)
}
// MARK: - 1051. Height Checker
func heightChecker(_ heights: [Int]) -> Int {
let solution = HeightChecker_Solution()
return solution.heightChecker(heights)
}
// MARK: - 1480. Running Sum of 1d Array
func runningSumOf1dArray(_ nums: [Int]) -> [Int] {
let solution = RunningSumOf1dArray_Solution()
return solution.runningSum(nums)
}
}