赞
踩
- 使用二分查找找到第一个值,以第一个值作为界限,分为左右两个区间
- 在左右两个区间分别使用二分查找
- 找左边的7,:找到中间位置的7之后,将中间位置的7作为结束位置,依次循环查找,知道start>end,返回start,这就是7第一次出现的位置
- 找右边的7,:找到中间位置的7之后,将中间位置的7作为开始位置,依次循环查找,知道start>end,返回end,这就是7最后一次出现的位置
左边索引
private static int getLeftIndex(int[] nums, int target) { int start = 0; int end = nums.length - 1; while (start <= end) { int mid = start + (end - start) / 2; if (nums[mid] == target) { end = mid - 1; } else if (nums[mid] < target) { start = mid + 1; } else { end = mid - 1; } } if (start >= nums.length || nums[start] != target) { return -1; } return start; }
右边索引
private static int getRightIndex(int[] nums, int target) { int start = 0; int end = nums.length - 1; while (start <= end) { int mid = start + (end - start) / 2; if (nums[mid] == target) { start = mid + 1; } else if (nums[mid] < target) { start = mid + 1; } else { end = mid - 1; } } if (end < 0 || nums[end] != target) { return -1; } return end; }
main函数 返回
leftIndex = 3
rightIndex = 5
int[] nums = {1,3,3,7,7,7,8,8,9};
int target = 7;
int leftIndex = getLeftIndex(nums, target);
int rightIndex = getRightIndex(nums, target);
System.out.println("leftIndex = " + leftIndex);
System.out.println("rightIndex = " + rightIndex);
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。