Chinaunix首页 | 论坛 | 博客
  • 博客访问: 269891
  • 博文数量: 170
  • 博客积分: 0
  • 博客等级: 民兵
  • 技术积分: 1709
  • 用 户 组: 普通用户
  • 注册时间: 2014-05-06 18:01
文章分类

全部博文(170)

文章存档

2016年(11)

2015年(130)

2014年(29)

分类: Java

2015-05-29 14:23:16


//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].
public class SearchforaRange {


public static void main(String[] args) {
// TODO 自动生成的方法存根


}
 public int[]  searchRange(int[] nums, int target) {
 int [] resultIndex={
 -1,-1
 };
 if(nums.length==0)
return resultIndex;
 if(nums[0]>target||nums[nums.length-1]  return resultIndex;
 int left=0;
 int right=nums.length-1;
 int mid;
 while(left<=right){
 mid=(left+right)/2;
 if(nums[mid]==target){
 int m=mid;
 while(m>=0&&nums[m]==target)
 m--;
 resultIndex[0]=m+1;
 int n=mid;
 while(n  n++;
 resultIndex[1]=n-1;
 break;
 }
 else if(nums[mid]>target){
 right=mid-1;
 }
 else {
left=mid+1;
}
 }
 return resultIndex;
 
 }
}

阅读(815) | 评论(0) | 转发(0) |
0

上一篇:SearchinRotatedSortedArray

下一篇:Valid Sudoku

给主人留下些什么吧!~~