前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >二分法的左右边界

二分法的左右边界

原创
作者头像
伯约同学
发布于 2022-03-02 14:20:15
发布于 2022-03-02 14:20:15
44200
代码可运行
举报
运行总次数:0
代码可运行

二分法的左右边界

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

题目一

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

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

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
```
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。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
```
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大的一个整数(所以先向下取整,后面leftmid+1),避免区间重叠陷入死循环。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

评论
登录后参与评论
暂无评论
推荐阅读
编辑精选文章
换一批
二分法还需要练习练习
力扣题目链接:https://leetcode-cn.com/problems/search-insert-position/
代码随想录
2021/10/20
4230
面试手撕算法系列:二分法
这些都是LeetCode上有的题目 手撕无非就是 树、链表、二分、字符串这些常用的数据结构
程序员小猿
2021/01/19
5720
面试手撕算法系列:二分法
二分法其实很简单,为什么老是写不对!!
相信很多人对二分法是又爱又恨,爱是在于它思想简单,效率确实高, 恨是恨在为什么总是写不对呢
代码随想录
2020/06/11
9920
Leetcode No.35 搜索插入位置(二分法)
给定一个排序数组和一个目标值,在数组中找到目标值,并返回其索引。如果目标值不存在于数组中,返回它将会被按顺序插入的位置。
week
2022/01/07
2590
35. Search Insert Position(二分法)
Given a sorted array and a target value, return the index if the target is found. If not, return the index where it would be if it were inserted in order.
yesr
2019/03/14
3060
搞定大厂算法面试之leetcode精讲5.二分查找
搞定大厂算法面试之leetcode精讲5.二分查找 视频教程(高效学习):点击学习 目录: 1.开篇介绍 2.时间空间复杂度 3.动态规划 4.贪心 5.二分查找 6.深度优先&广度优先 7.双指针 8.滑动窗口 9.位运算 10.递归&分治 11剪枝&回溯 12.堆 13.单调栈 14.排序算法 15.链表 16.set&map 17.栈 18.队列 19.数组 20.字符串 21.树 22.字典树 23.并查集 24.其他类型题 二分搜索 时间复杂度O(logn) 步骤: 从数组中间的元素开始,如果中
全栈潇晨
2021/11/24
3300
数组:每次遇到二分法,都是一看就会,一写就废
给定一个排序数组和一个目标值,在数组中找到目标值,并返回其索引。如果目标值不存在于数组中,返回它将会被按顺序插入的位置。
代码随想录
2020/08/27
5970
数组:每次遇到二分法,都是一看就会,一写就废
吃透二分查找—— LeetCode 第 33、34、35 题记
昨天没能完成 34,今天来补上。恰好第 35 题也是二分查找算法的应用,放到一起来记录。
TTTEED
2020/07/09
1.9K0
Leetcode34在排序数组中查找元素的第一个和最后一个位置(二分法求解)
给定一个按照升序排列的整数数组 nums,和一个目标值 target。找出给定目标值在数组中的开始位置和结束位置。
伯约同学
2022/03/19
2490
剑指Offer题解 - Day6
首先考虑通过遍历数组进行查找重复次数。该方法没有合理利用有序数组的前提条件,适合无序数组的元素统计。
chuckQu
2022/08/19
1440
【剑指offer:在排序数组中查找数字】搜索左右边界:从两边向中间、二分查找
二分查找一般用来查找数字在有序数组中是否出现过。进一步想,它可以用来不断在子序列中搜索对应数字。所以,我们就可以用它来向左边子序列中不断搜索,确认左边界;同样的思路,确认右边界。
心谭博客
2020/04/21
1.6K0
二分查找总结
二分查找是在每次匹配后,将查找的空间一分为二的算法,二分查找应该是有序的数组进行查找.
Tim在路上
2020/08/04
4850
【算法】二分法 ② ( 排序数组中查找目标值 | 二分法的经典写法 | 在排序数组中查找元素的最后一个位置 | 二分法的通用模板 )
https://leetcode.cn/problems/binary-search/
韩曙亮
2023/03/30
7890
【算法】二分法 ③ ( 山脉数组的峰顶索引 | 枚举法 | 二分法 )
https://leetcode.cn/problems/peak-index-in-a-mountain-array/description/
韩曙亮
2023/03/30
6670
二分法注意点_二分法怎么用
我相信对很多读者朋友来说,编写二分查找的算法代码属于玄学编程,虽然看起来很简单,就是会出错,要么会漏个等号,要么少加个 1。
全栈程序员站长
2022/11/18
3600
二分法注意点_二分法怎么用
【算法】递归算法 ② ( 使用递归实现二分法 | if else 编码优化 )
https://leetcode.cn/problems/binary-search/
韩曙亮
2023/03/30
6990
算法笔记(一)
给定一个 n 个元素有序的(升序)整型数组 nums 和一个目标值 target,写一个函数搜索 nums 中的 target,如果目标值存在返回下标,否则返回 -1。
chuckQu
2022/08/19
6360
二分算法详解
这是一道单纯的朴素二分模版题,当 left == right 时的这种情况也是需要考虑的,因为不排除数组中只有一个数的情况,或者是二分到数组中只剩一个数的情况,所以循环条件要写 left <= right
2的n次方
2024/10/15
1020
二分算法详解
二分查找为什么让面试者挂的这么惨?
二分查找可以说是所有算法中最基础、最容易理解的算法之一了,但事实上也是挂科率最高的考题之一,在各个大厂的应届生面试中,这样的评价屡见不鲜: 谈项目的时候来聊的好好的,叫他写个二分搜索却写不出来。对此我不做评论,就二分查找而言,我觉得它并没有大家想象那样容易,用“思路很简单,细节是魔鬼”来形容最贴切不过了,不信咱们来一步步瞧一瞧。
用户3806669
2021/03/11
3400
深度解析算法之二分查找(2)
题目链接 给定一个 n 个元素有序的(升序)整型数组 nums 和一个目标值 target ,写一个函数搜索 nums 中的 target,如果目标值存在返回下标,否则返回 -1。
Undoom
2025/04/20
1130
深度解析算法之二分查找(2)
推荐阅读
相关推荐
二分法还需要练习练习
更多 >
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
本文部分代码块支持一键运行,欢迎体验
本文部分代码块支持一键运行,欢迎体验