leetcode------Search for a Range

标题: Search for a Range
通过率: 27.7%
难度: 中等

Given a sorted array of integers, find the starting and ending position of a given target value.

Your algorithm's runtime complexity must be in the order of O(log n).

If the target is not found in the array, return [-1, -1].

For example,
Given [5, 7, 7, 8, 8, 10] and target value 8,
return [3, 4].

本题就是对应target的开始和结束位置,二分法查找。每次比较下开始位置和结束位置,那么开始结束位置的初始值要设定好,

开始位置设定成数组的最大位置。结束位置设定成0,,最后验证下对应位置是不是target,如果不是那就将数组置-1

代码如下:

 1 public class Solution {

 2     public int[] searchRange(int[] A, int target) {

 3         int res []={A.length-1,0};

 4         bs(A,target,0,A.length-1,res);

 5         if(A[res[0]]!=target){

 6             res[0]=-1;

 7             res[1]=-1;

 8         }

 9         return res;

10     }

11     public void bs(int[] A,int target,int start,int end,int [] res){

12         if(start<=end){

13         int mid=(start+end)/2;

14         if(A[mid]==target){

15             if(mid<res[0])res[0]=mid;

16             if(mid>res[1])res[1]=mid;

17         }

18         bs(A,target,start,mid-1,res);

19         bs(A,target,mid+1,end,res);

20         }

21     }

22 }

 

你可能感兴趣的:(LeetCode)