Find First and Last Position of Element in Sorted Array in Java
The challenge
Given an array of integers nums sorted in ascending order, find the starting and ending position of a given target value.
If target is not found in the array, return [-1, -1].
Follow up: Could you write an algorithm with O(log n) runtime complexity?
Example 1:
Example 2:
Example 3:
Constraints:
0 <= nums.length <= 10<sup>5</sup>-10<sup>9</sup> <= nums[i] <= 10<sup>9</sup>numsis a non-decreasing array.-10<sup>9</sup> <= target <= 10<sup>9</sup>
The solution in Java code
class Solution {
public int[] searchRange(int[] nums, int target) {
int first = -1, last = -1;
for (int i=0; i<nums.length; i++) {
if (nums[i]==target) first = i;
continue;
}
for (int i=nums.length-1; i>=0; i--) {
if (nums[i]==target) last = i;
continue;
}
return new int[] {last, first};
}
}