class Solution {
public int search(int[] nums, int target) {
int l = 0;
int r = nums.length-1;
while (l<=r){
int m = (r-l)+l;
if (nums[m]==target){
return m;
}else if (target<nums[m]){
r = m-1;
}else {
l = m+1;
}
}
return -1;
}
}
public int mySqrt(int x) {
if (x==0){return 0;}
if (x==1){return 1;}
int l = 0;
int r = x;
while(l<=r){
int m = (r-l)/2+l;
if (x/m==m){
return m;
}else if(x/m<m){ // 16 / 8 < 8
r = m-1;
}else if(x/m>m){
l = m + 1;
}
}
return r;
}
2.2 二分查找模板 II
分查找的高级模板。它用于查找需要访问数组中当前索引及其直接右邻居索引的元素或条件。
int binarySearch(int[] nums, int target){
if(nums == null || nums.length == 0)
return -1;
int left = 0, right = nums.length;
while(left < right){
// Prevent (left + right) overflow
int mid = left + (right - left) / 2;
if(nums[mid] == target){ return mid; }
else if(nums[mid] < target) { left = mid + 1; }
else { right = mid; }
}
// Post-processing:
// End Condition: left == right
if(left != nums.length && nums[left] == target) return left;
return -1;
}
关键属性
一种实现二分查找的高级方法。
查找条件需要访问元素的直接右邻居。
使用元素的右邻居来确定是否满足条件,并决定是向左还是向右。
保证查找空间在每一步中至少有 2 个元素。
需要进行后处理。 当你剩下 1 个元素时,循环 / 递归结束。 需要评估剩余元素是否符合条件。
2.3 二分查找模板 III
模板 3 是二分查找的另一种独特形式。 它用于搜索需要访问当前索引及其在数组中的直接左右邻居索引的元素或条件。
int binarySearch(int[] nums, int target) {
if (nums == null || nums.length == 0)
return -1;
int left = 0, right = nums.length - 1;
while (left + 1 < right){
// Prevent (left + right) overflow
int mid = left + (right - left) / 2;
if (nums[mid] == target) {
return mid;
} else if (nums[mid] < target) {
left = mid;
} else {
right = mid;
}
}
// Post-processing:
// End Condition: left + 1 == right
if(nums[left] == target) return left;
if(nums[right] == target) return right;
return -1;
}