JS实现二分查找

最近在面试的时候被问到手写实现二分查找,虽然二分查找很早就听过,也知道实现原理,但是手撸起来,总是差点意思,正好复习一下。作为前端程序员,可能面试绝大部分公司不需要能写很复杂的算法问题,但是这些基本的数据结构和常见算法,还是得能手撸出来。

什么是二分查找

公众号:Code程序人生,个人网站:https://creatorblog.cn

二分查找是一种在有序数组中查找目标元素的算法,它的基本思想是每次比较数组的中间元素和目标元素,如果相等则返回中间元素的索引,如果不相等则根据比较结果缩小查找范围,直到找到目标元素或者查找范围为空。二分查找的时间复杂度是O(log n),其中n是数组的长度,它比顺序查找的时间复杂度O(n)要快得多。

如何实现二分查找

下面是用js语言实现二分查找的代码示例,其中arr是有序数组,target是要查找的元素,函数返回target在arr中的索引,如果不存在则返回-1。

// 定义二分查找函数
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;}}// 如果查找范围为空,说明目标元素不存在,返回-1return -1;
}// 测试代码
let arr = [1, 3, 5, 7, 9, 11, 13, 15]; // 定义一个有序数组
let target = 9; // 定义要查找的元素
let index = binarySearch(arr, target); // 调用二分查找函数
console.log(index); // 输出结果,应该是4

二分查找的实现原理

  1. 首先,定义查找范围的左右边界,初始时为整个数组的范围,即左边界为0,右边界为数组的长度减1。
  2. 然后,计算查找范围的中间元素的索引,可以用左边界加右边界除以2的下取整来得到,例如,如果左边界是0,右边界是7,那么中间元素的索引是(0+7)/2=3.5,下取整是3。
  3. 接着,比较中间元素和目标元素,如果相等,说明找到了目标元素,返回中间元素的索引;如果不相等,说明目标元素在中间元素的左边或者右边,需要缩小查找范围。
  4. 如果中间元素小于目标元素,说明目标元素在中间元素的右边,那么将左边界移动到中间元素的右边,即左边界等于中间元素的索引加1,右边界不变,这样就缩小了查找范围的一半;如果中间元素大于目标元素,说明目标元素在中间元素的左边,那么将右边界移动到中间元素的左边,即右边界等于中间元素的索引减1,左边界不变,同样缩小了查找范围的一半。
  5. 重复第2步到第4步,直到找到目标元素或者查找范围为空,如果查找范围为空,说明目标元素不存在,返回-1。

总结

本文介绍了二分查找的定义、时间复杂度、实现原理和代码示例。

二分查找是一种在有序数组中查找目标元素的算法,它的时间复杂度是O(log n),比顺序查找的时间复杂度O(n)要快得多。

二分查找的实现原理是每次比较数组的中间元素和目标元素,如果相等则返回中间元素的索引,如果不相等则根据比较结果缩小查找范围,直到找到目标元素或者查找范围为空。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/161481.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Azure Machine Learning - 搜索中的语义排名

目录 什么是语义排名&#xff1f;语义排名的工作原理如何收集和总结输入语义排名的输出如何对摘要进行评分 语义功能和限制 在 Azure AI 搜索中&#xff0c;“语义排名”通过使用语言理解对搜索结果重新排名来显著提高搜索相关性&#xff0c; 本文概括性地介绍了语义排名工作原…

Nodejs JavaScript 字符串加密

情景 问题的场景是这样的&#xff1a;我们需要在浏览器cookie中存储用户名&#xff0c;但又不想直接明文存储&#xff0c;所以对它进行了简单的加密存储。 因为是简单的加密&#xff0c;目的只是不希望明文存储。我们使用了Base64 编码&#xff0c;使得cookie里的存储不可只读…

Arthas 监听 Docker 部署的java项目CPU占比高的信息

1、Linux上安装Arthas wget https://alibaba.github.io/arthas/arthas-boot.jar2、docker ps 查看目标项目的容器ID 3、copy Arthas 到目标容器中 (注意有 &#x1f615; ) docker cp arthas-boot.jar d97e8666666:/4、进入到目标容器目录中 docker exec -it d97e8666666 /b…

5-7求三种数的和

#include<stdio.h> int main(){double sum10;double sum20;double sum30;double sum;int i;for(i1;i<100;i){sum1sum1i;}printf("sum1结果是&#xff1a;%15.6f\n",sum1);for(i1;i<50;i){sum2sum2i*i;}printf("sum2结果是&#xff1a;%15.6f\n"…

TS是什么、为什么、怎么办

TS是什么 javascript程序的静态类型检查器 为什么要用TS js编写时在预期不同类型值的地方使用了某种类型的值&#xff0c;导致常见的类型错误 js只能提供动态类型&#xff0c;也就是运行一下代码才能知道发生了什么&#xff0c;需要静态类型的检查 TS怎么用 1、安装vscode…

连接服务器的脚本

对于记不住的服务器密码且不愿用三方工具俺简单写了个脚本&#xff08;检测下最近shell脚本的学习效果咋样&#xff09; expect 是处理交互的一种脚本语言&#xff0c;spawn启动指定进程 -> expect获取指定关键字 -> send想指定进程发送指定指令 -> 执行完成后退出 sp…

Oracle:poor sql导致的latch: cache buffers chains案例

巡检时&#xff0c;执行如下sql发现长会话&#xff1a; SELECT SE.SID,SE.SERIAL#,TO_CHAR(LOGON_TIME,YYYY-MM-DD HH24:MI:SS),SE.STATUS,SE.OSUSER,SE.MACHINE,SE.PROGRAM,SE.BLOCKING_SESSION, SE.SQL_ID,SE.PREV_SQL_ID ,SE.EVENT,SE.P1TEXT,SE.P1,SE.P2TEXT,SE.P2,SE.P3…

LeetCode1161. Maximum Level Sum of a Binary Tree

文章目录 一、题目二、题解 一、题目 Given the root of a binary tree, the level of its root is 1, the level of its children is 2, and so on. Return the smallest level x such that the sum of all the values of nodes at level x is maximal. Example 1: Input:…

visionOS空间计算实战开发教程Day 4 初识ImmersiveSpace

细心的读者会发现在在​​Day1​​​和​​Day2​​​的示例中我们使用的都是​​WindowGroup​​。 main struct visionOSDemoApp: App {var body: some Scene {WindowGroup {ContentView()}} } 本节我们来认识在visionOS开发中会经常用到的另一个概念​​ImmersiveSpace​​…

Spark---集群搭建

Standalone集群搭建与Spark on Yarn配置 1、Standalone Standalone集群是Spark自带的资源调度框架&#xff0c;支持分布式搭建&#xff0c;这里建议搭建Standalone节点数为3台&#xff0c;1台master节点&#xff0c;2台worker节点&#xff0c;这虚拟机中每台节点的内存至少给…

transformer之KV Cache

一、为什么要研究KV Cache 非常有效的加速推理速度&#xff0c;效果如下所示&#xff1a; import numpy as np import time import torch from transformers import AutoModelForCausalLM, AutoTokenizer NAME_OR_PATH r*************** device "cuda" if torch.cu…

中职组网络安全 Server-Hun-1.img Server-Hun-2.img

一串密码 smbuser用户和密码登录ssh还是失败提示需要密钥&#xff0c;尝试ftp登录成功 发现密钥存放在.ssh/下&#xff0c;在kali上生成一个密钥&#xff0c;通过上传到.ssh/下&#xff0c;将其替换掉 使用kali生成密钥 登录成功,但是无法拿到root目录下的flag 获取root用户权限…

电子学会C/C++编程等级考试2022年12月(一级)真题解析

C/C++等级考试(1~8级)全部真题・点这里 第1题:加一 输入一个整数x,输出这个整数加1后的值,即x+1的值。 时间限制:1000 内存限制:65536输入 一个整数x(0 ≤ x ≤ 1000)。输出 按题目要求输出一个整数。样例输入 9样例输出 10 答案: //参考答案: #include<bits/st…

opencv-常用代码

以下是一些OpenCV中常用的代码片段&#xff0c;涵盖了一些基本的图像处理和计算机视觉任务。 加载和显示图像: import cv2# 读取图像 img cv2.imread(image.jpg)# 显示图像 cv2.imshow(Image, img) cv2.waitKey(0) cv2.destroyAllWindows()调整图像大小: resized_img cv2.res…

鸿蒙4.0开发笔记之DevEco Studio页面操作router的pushUrl页面跳转与back返回上一页(五)

一、认识组件 关于HarmonyOS中ArkTS的基础组件请参见文章鸿蒙4.0开发笔记之ArkTs语言基础与基本组件结构&#xff08;四&#xff09; 二、实现页面跳转pushUrl 1、操作说明 实现页面跳转的核心便是router.pushUrl的调用&#xff0c;操作起来也很简单&#xff0c;总共就四步…

Laravel 安装(笔记一)

目录 第一步、Laravel 一般使用 composer安装 第二步、使用composer安装项目 第三步、配置环境 第四步、访问域名&#xff0c;安装完成 Laravel 官网 l​​​​​​​Installation - Laravel 中文网 为 Web 工匠创造的 PHP 框架 第一步、Laravel 一般使用 composer安装 如…

13.求面积[有问题]

#include<stdio.h> #include<math.h> #include<bits/stdc.h> using namespace std;void fun(double a,b,c) {double p,c;p (abc)/2;c sqrt(p*(p-a)*(p-b)*(p-c));printf("面积是&#xff1a;%lf",c); }int main(){double a,b,c;scanf("%lf,%…

《golang设计模式》第三部分·行为型模式-06-备忘录模式(Memento)

文章目录 1. 概述1.1 角色1.2 类图 2. 代码示例2.1 设计2.2 代码2.3 类图 1. 概述 备忘录&#xff08;Memento&#xff09;用于在不破坏目标对象封装特性的基础上&#xff0c;将目标对象内部的状态存储到外部对象中&#xff0c;以备之后恢复状态时使用。 1.1 角色 Originato…

【洛谷 B2008】计算 (a+b)×c 的值 题解(顺序结构+四则运算)

计算 (ab)c 的值 题目描述 给定 3 3 3 个整数 a , b , c a,b,c a,b,c&#xff0c;计算表达式 ( a b ) c (ab) \times c (ab)c 的值。 输入格式 输入仅一行&#xff0c;包括三个整数 a , b , c a,b,c a,b,c&#xff0c;数与数之间以一个空格分开。 输出格式 输出一行…

如何访问linux上的web服务

1.获取服务运行端口 例如8080 2.如果时vmware 需要先配置转发端口和主机ip 主机ip需要未使用的 例如&#xff1a; 3.查看虚拟机防火墙设置 centos8 为例 &#xff1a; firewall-cmd --zonepublic --list-ports 查看放通端口 如果没有放通 firewall-cmd --zonepublic --add-p…