1. 题目解析
题目非常简单,就是查找一个 target。
2. 算法原理
根据最基本的二分查找算法:
在一个有序数组里面,左右边界分别是 left 和 right,mid 指向的位置的值是 x
1. x < target,left = mid + 1
2. x > target,right = mid - 1
3. x == target,返回结果即可·
3. 代码编写
class Solution { public: int search(vector<int>& nums, int target) { int left = 0, right = nums.size() - 1; while(left <= right) { int mid = left + (right - left) / 2; if(nums[mid] < target) left = mid + 1; else if(nums[mid] > target) right = mid - 1; else if(nums[mid] == target) return mid; } return -1; } };
4. 第一种二分模板
这个就是我们的第一个模板啦~
while (left <= right) {
int mid = left + (right - left) / 2;
if ( ... ) left = mid + 1;
else if ( ... ) right = mid - 1;
else if ( ... ) return mid;
}
写在最后:
以上就是本篇文章的内容了,感谢你的阅读。
如果感到有所收获的话可以给博主点一个赞哦。
如果文章内容有遗漏或者错误的地方欢迎私信博主或者在评论区指出~