-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathQ35SearchInsertPosition.java
More file actions
52 lines (45 loc) · 1.6 KB
/
Q35SearchInsertPosition.java
File metadata and controls
52 lines (45 loc) · 1.6 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
/*
Description:
Given a sorted array of distinct integers and a target value, return the index if the target is found.
If not, return the index where it would be if it were inserted in order.
You must write an algorithm with O(log n) runtime complexity.
Example 1:
Input: nums = [1,3,5,6], target = 5
Output: 2
Example 2:
Input: nums = [1,3,5,6], target = 2
Output: 1
Example 3:
Input: nums = [1,3,5,6], target = 7
Output: 4
*/
public class Q35SearchInsertPosition {
public static void main(String[] args) {
Q35SearchInsertPosition test = new Q35SearchInsertPosition();
System.out.println(test.searchInsert(new int[] {1, 3, 5, 6}, 5));
System.out.println(test.searchInsert(new int[] {1, 3, 5, 6}, 2));
System.out.println(test.searchInsert(new int[] {1, 3, 5, 6}, 7));
System.out.println(test.searchInsert(new int[] {1, 3, 5, 6}, 0));
}
public int searchInsert(int[] nums, int target) {
int start = 0;
int end = nums.length-1;
while(end - start > 0) {
int midpoint = (start + end) / 2;
if (target == nums[midpoint]) {
return midpoint;
} else if (target < nums[midpoint]) {
end = midpoint - 1;
} else {
start = midpoint + 1;
}
}
if(target <= nums[start]){
return start;
} else{
return start+1;
}
}
}
//Runtime: 0 ms, faster than 100.00% of Java online submissions for Search Insert Position.
//Memory Usage: 43.8 MB, less than 20.75% of Java online submissions for Search Insert Position.