二分查找是一种高效的查找算法,但是对于部分问题,需要对二分查找进行一些修改。通常来说,需要修改的问题有以下两种情况:
代码示例:
int binarySearch(int[] arr, int target) { int low = 0, high = arr.length - 1; while (low <= high) { int mid = low + ((high - low) >> 1); if (arr[mid] <= target) { if (mid == arr.length - 1 || arr[mid + 1] > target) { return mid; } else { low = mid + 1; } } else { high = mid - 1; } } return -1; }
代码示例:
int binarySearch(int[] arr, int target) { int low = 0, high = arr.length - 1; while (low <= high) { int mid = low + ((high - low) >> 1); if (arr[mid] < target) {