左右夹逼算法

什么是左右夹逼算法

左右夹逼算法是一种基于有序数组或有序列表的搜索算法,主要用于查找目标元素在有序数组中的位置或查找范围。

function binarySearch(arr, target) {
  let left = 0
  let right = arr.length - 1
  while (left <= right) {
    let mid = Math.floor((left + right) / 2)
    if (arr[mid] === target) {
      return mid
    } else if (arr[mid] < target) {
      left = mid + 1
    } else {
      right = mid - 1
    }
  }
  return -1
}

这个算法的思路是先设定两个指针 left 和 right 分别指向数组的最左和最右两个位置,然后计算中间位置的索引 mid,将目标值与中间值进行比较,如果目标值等于中间值,则直接返回中间值的索引;如果目标值小于中间值,则将右指针移动到 mid - 1 的位置;如果目标值大于中间值,则将左指针移动到 mid + 1 的位置。如此循环直到左指针大于右指针或者找到目标值为止。

左右夹逼算法的时间复杂度为 O(log n),相较于线性查找算法,它具有更高的效率。

JavaScript 的左右夹逼算法通常用于以下场景:

  1. 寻找数组中满足特定条件的元素,例如二分查找算法;
  2. 计算数组中符合特定条件的元素的数量,例如统计有序数组中某个数出现的次数;
  3. 优化数组遍历的时间复杂度,例如在升序或降序的数组中查找特定值时,可以通过左右夹逼算法实现更快的查找效率。
    总之,左右夹逼算法是一个高效的算法,在各种场景下都有广泛的应用。

左右夹逼算法题目

题目:给出一个有n个元素的数组S,S中是否有元素a,b,c满足a+b+c=0?找出数组S中所有满足条件的三元组。

数据范围:,数组中各个元素值满足
空间复杂度:,时间复杂度

注意:
三元组(a、b、c)中的元素必须按非降序排列。(即a≤b≤c)
解集中不能包含重复的三元组。
例如,给定的数组 S = {-10 0 10 20 -10 -40},解集为(-10, -10, 20),(-10, 0, 10)

/**
 * (1)首先对数组进行排序(从小到大)
 * (2)依次取出第 i 个数(i从0开始),并且不重复的选取(跳过重复的数)
 * (3)这样问题就转换为 2 个数求和的问题(可以用双指针解决方法)
 *  2 数求和问题
 *     (4)定义两个指针:左指针(left) 和 右指针(right)
 *     (5)找出固定 left, 此时left所指的位置为数组中最小数,再找到两个数和 不大于 target 的最大 right 的位置
 *     (6)调整 left 的位置(后移),求解和是否为 target O(n)
 *     (7)时间复杂度:O(nlogn) + O(n)
*/
未完待续
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值