-
Notifications
You must be signed in to change notification settings - Fork 1
Expand file tree
/
Copy pathSolution.kt
More file actions
43 lines (34 loc) · 1.26 KB
/
Solution.kt
File metadata and controls
43 lines (34 loc) · 1.26 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
package problems.searchInRotatedSortedArray
import readmeGeneration.ProblemDifficulty
import readmeGeneration.ProblemSolution
@ProblemSolution(
33, "Search in Rotated Sorted Array", ProblemDifficulty.MEDIUM,
"https://leetcode.com/problems/search-in-rotated-sorted-array/"
)
class Solution {
fun search(nums: IntArray, target: Int): Int {
return binarySearch(nums, 0, nums.lastIndex, target)
}
private fun binarySearch(nums: IntArray, lo: Int, hi: Int, target: Int): Int {
if (hi < lo) return -1
val mid = lo + (hi - lo) / 2
println(mid)
if (target == nums[mid]) return mid
// if left part is sorted
if (nums[lo] <= nums[mid]) {
// if target is in left
if (target >= nums[lo] && target < nums[mid]) {
return binarySearch(nums, lo, mid - 1, target)
}
// else search in right
return binarySearch(nums, mid + 1, hi, target)
}
// left part is not sorted then
// if target is in sorted right
if (target > nums[mid] && target <= nums[hi]) {
return binarySearch(nums, mid + 1, hi, target)
}
// else search in left
return binarySearch(nums, lo, mid - 1, target)
}
}