35. 搜索插入位置
题目
- 给定一个排序数组和一个目标值,在数组中找到目标值,并返回其索引。如果目标值不存在于数组中,返回它将会被按顺序插入的位置。
理解
:最基础的二分搜索
while(left < right)
int mid = (right +left) >> 1 —————————- 向下取整
if(target < num[mid]) left = mid + 1;—————-这样不会陷入死循环
else right = mid;
例题
输入: [1,3,5,6], 5
输出: 2
输入: [1,3,5,6], 2
输出: 1
解题
二分法
代码
1 | int searchInsert(vector<int>& nums, int target) { |