二分法的左右边界

简介: 二分法的左右边界

二分法的左右边界

二分法用起来还是挺好用的,就是每次我总是纠结边界条件到底如何确定,用小于号还是小于等于号,满足条件后left是mid还是mid+1,为此专门做了两道简单题,整理了下思路。

题目一

给定一个排序数组和一个目标值,在数组中找到目标值,并返回其索引。如果目标值不存在于数组中,返回它将会被按顺序插入的位置。

请必须使用时间复杂度为 O(log n) 的算法

var searchInsert = function(nums, target) {
  let left = 0
  let right = nums.length
  if(nums[0] > target) { return 0}
  while(left < right){
​    let mid = Math.floor(left + (right - left)/2)
​    if(nums[mid] < target){
​      left = mid + 1
​    }else if(nums[mid] > target){
​      right = mid
​    }else {
​      return mid
​    }
  }
  return left
};

题目二

给定一个 n 个元素有序的(升序)整型数组 nums 和一个目标值 target ,写一个函数搜索 nums 中的 target,如果目标值存在返回下标,否则返回 -1。

var search = function(nums, target) {
  let left = 0
  let right = nums.length
  while(left < right){
​    let mid = Math.floor(left + (right - left)/2)
​    if(nums[mid] < target){
​      left = mid + 1
​    }else if(nums[mid] > target){
​      right = mid
​    }else{
​      return mid
​    }
  }
  return -1
};

我一般做二分法的题都是使用小于号来做判断

while(left<right)的这种写法实际上也确定了每次的判断范围是[left,right)

这也意味着当我拿到mid来判断是左边还是右边的边界的时候,如果mid在左边的话一定不能在这个区间内,所以要进行+1的操作,如果是当做右边界则没有任何问题,毕竟这个值实际上是不会取到的。

当满足条件需要返回结果的时候,我们需要结合题意来指定输出。

特别值得注意的是mid的取值用的是Math.floor()方法这同样是因为我们想要的值是一个比mid大的一个整数(所以先向下取整,后面left取mid+1),避免区间重叠陷入死循环。

相关文章
|
6月前
|
算法 测试技术 C#
【贪心】【分类讨论】2499. 让数组不相等的最小总代价
【贪心】【分类讨论】2499. 让数组不相等的最小总代价
|
6月前
leetcode-435:无重叠区间
leetcode-435:无重叠区间
32 0
|
算法
【算法专题突破】双指针 - 有效三角形的个数(5)
【算法专题突破】双指针 - 有效三角形的个数(5)
30 0
|
2月前
|
人工智能 Java
两个非重叠子数组的最大和
两个非重叠子数组的最大和
29 0
|
6月前
|
算法
DAY-7 | 牛客-BM21 寻找旋转数组的最小元素:二分法分治思想真的很可靠
这是一个关于编程题目的摘要:题目是牛客网上的&quot;BM21 旋转数组的最小数字&quot;,要求找到旋转数组中的最小数字。题解介绍了使用二分查找算法来解决此问题,因为其时间复杂度优于暴力搜索的线性时间复杂度。二分查找的核心是通过比较中间元素与右端元素的大小,不断缩小搜索范围,最终找到最小值。代码示例展示了如何实现这个算法。总结中强调了二分查找适用于部分有序数组,并指出了解决这类问题的关键在于理解数组的二段单调性。
42 1
|
6月前
代码随想录Day30 贪心05 LeetCode T435无重叠区间 T763划分字母区间 T56 合并区间
代码随想录Day30 贪心05 LeetCode T435无重叠区间 T763划分字母区间 T56 合并区间
50 0
|
6月前
|
算法 测试技术 C#
【动态规划】【广度优先搜索】LeetCode:2617 网格图中最少访问的格子数
【动态规划】【广度优先搜索】LeetCode:2617 网格图中最少访问的格子数
|
算法 索引
算法:二分查找算法/朴素二分/查找区间左右端点二分
算法:二分查找算法/朴素二分/查找区间左右端点二分
|
人工智能 算法 BI
贪心算法——区间选点与最大不相交区间数
贪心算法——区间选点与最大不相交区间数
68 0
LeetCode1477-找两个和为目标值且不重叠的子数组
LeetCode1477-找两个和为目标值且不重叠的子数组