当前位置:首页 > JavaScript

js实现二分查找

2026-01-30 16:22:59JavaScript

二分查找的基本原理

二分查找是一种在有序数组中查找特定元素的算法。通过将数组分成两半,比较中间元素与目标值,逐步缩小搜索范围,直到找到目标或确定不存在。

实现二分查找的步骤

初始化指针 定义两个指针leftright,分别指向数组的起始和末尾位置。

循环条件left小于等于right时,继续循环。计算中间索引mid,使用Math.floor((left + right) / 2)避免浮点数问题。

比较中间值 若中间元素等于目标值,直接返回mid。若中间元素小于目标值,调整leftmid + 1。若中间元素大于目标值,调整rightmid - 1

未找到的情况 循环结束后仍未找到目标值,返回-1表示未找到。

代码实现示例

function binarySearch(arr, target) {
    let left = 0;
    let right = arr.length - 1;

    while (left <= right) {
        const 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;
}

// 示例用法
const sortedArray = [1, 3, 5, 7, 9];
console.log(binarySearch(sortedArray, 5)); // 输出: 2
console.log(binarySearch(sortedArray, 10)); // 输出: -1

边界条件与注意事项

数组必须有序 二分查找要求输入数组是有序的,否则结果不可预测。若数组无序,需先排序。

整数溢出问题 在计算mid时,left + right可能导致整数溢出。更安全的写法是使用left + Math.floor((right - left) / 2)

重复元素处理 若数组中有重复元素,上述代码返回任意一个匹配的索引。如需返回第一个或最后一个匹配项,需进一步调整逻辑。

时间复杂度分析

二分查找的时间复杂度为O(log n),其中n是数组长度。每次迭代都将搜索范围减半,效率远高于线性查找的O(n)。

js实现二分查找

标签: js
分享给朋友:

相关文章

js实现动画

js实现动画

使用 CSS 动画与 JavaScript 控制 通过 JavaScript 动态添加或移除 CSS 类来触发动画。CSS 定义关键帧(@keyframes),JavaScript 通过 classL…

js树实现

js树实现

树的基本概念 树是一种非线性的数据结构,由节点和边组成。每个节点包含一个值和指向子节点的引用。树的顶部节点称为根节点,没有子节点的节点称为叶节点。 树的实现方式 在JavaScript中,树可以通…

利用js实现

利用js实现

使用 JavaScript 实现 在 JavaScript 中,可以通过多种方式实现功能,具体取决于需求。以下是几种常见的方法: 方法一:使用原生 JavaScript // 示例代码…

js 实现滚动

js 实现滚动

实现滚动的方法 使用 window.scrollTo() window.scrollTo() 方法可以滚动到文档中的特定位置。可以指定 x 和 y 坐标,或者使用平滑滚动的选项。 // 滚动到指定…

js进度条实现

js进度条实现

使用HTML和CSS创建基础结构 在HTML中创建一个容器元素用于显示进度条,通常使用<div>元素。CSS用于设置进度条的样式,包括宽度、高度、颜色和圆角等属性。 <div c…

js实现下拉刷新

js实现下拉刷新

监听触摸事件 通过监听 touchstart、touchmove 和 touchend 事件来检测用户下拉手势。记录触摸起始位置和移动距离。 let startY = 0; let curr…