leetcode-cn.com/problems/se…java
給定一個排序數組和一個目標值,在數組中找到目標值,並返回其索引。若是目標值不存在於數組中,返回它將會被按順序插入的位置。算法
你能夠假設數組中無重複元素。數組
示例 1:bash
輸入: [1,3,5,6], 5
輸出: 2
複製代碼
示例 2:spa
輸入: [1,3,5,6], 2
輸出: 1
複製代碼
示例 3:code
輸入: [1,3,5,6], 7
輸出: 4
複製代碼
示例 4:cdn
輸入: [1,3,5,6], 0
輸出: 0
複製代碼
left
和右側下標right
,再計算中間下標mid
nums[mid]
和target
之間的大小進行判斷,相等則直接返回下標,nums[mid]<target
則left右移,nums[mid]>target
則right左移二分查找的思路不難理解,可是邊界條件容易出錯,好比循環結束條件中left和right的關係,更新left和right位置時要不要加1減1。blog
下面給出兩個能夠直接套用的模板,記住就行了,免除邊界條件出錯。排序
class Solution {
public int searchInsert(int[] nums, int target) {
int left = 0, right = nums.length - 1; // 注意
while(left <= right) { // 注意
int mid = (left + right) / 2; // 注意
if(nums[mid] == target) { // 注意
// 相關邏輯
} else if(nums[mid] < target) {
left = mid + 1; // 注意
} else {
right = mid - 1; // 注意
}
}
// 相關返回值
return 0;
}
}
複製代碼
或索引
class Solution {
public int searchInsert(int[] nums, int target) {
int left = 0, right = nums.length; // 注意
while(left < right) { // 注意
int mid = (left + right) / 2; // 注意
if(nums[mid] == target) {
// 相關邏輯
} else if(nums[mid] < target) {
left = mid + 1; // 注意
} else {
right = mid; // 注意
}
}
// 相關返回值
return 0;
}
}
複製代碼
class Solution {
public int searchInsert(int[] nums, int target) {
int left = 0, right = nums.length - 1;
while(left <= right) {
int mid = (left + right) / 2;
if(nums[mid] == target) {
return mid;
} else if(nums[mid] < target) {
left = mid + 1;
} else {
right = mid - 1;
}
}
return left;
}
}
複製代碼
後臺回覆「算法」,加入每天算法羣