【javascript算法】二分查找法

本文详细介绍了二分查找算法的定义、流程,并通过流程图帮助理解查找过程。接着,展示了JavaScript实现二分查找的源码及测试结果,讨论了在非有序数组中寻找最大值的拓展思考。欢迎探讨交流。
摘要由CSDN通过智能技术生成

目录

1.二分查找算法

1.1定义 

1.2流程图

1.3查找过程

2.javascript的实现

2.1 源码

2.2测试结果

2.3拓展题


1.二分查找算法

本文是根据有序数组升序的顺序来实现的

1.1定义 

  二分查找也称折半查找(Binary Search),它是一种效率较高的查找方法。但是,折半查找要求线性表必须采用顺序存储结构,而且表中元素按关键字有序排列。

1.2流程图

*为什么是 left <= right  ?

  因为始终要保证查找的对象内至少含有一个元素,且确保能判断对于left和right指向同一个元素的情况。

*为什么是left=middle +1 || right=middle -1 ?

  因为在第一次判断的时候就已经排除了middle = find 的这个可能,为了提升效率。可以直接将middle值减去不再第二次判断的序列之中

1.3查找过程

  首先,我们需要明确的一个问题就是:二分查找是一个效率较高的算法,但是这是相对于有序的数组来说。接下来就用图解的方法给大家解释一下二分查找算法的查找过程:

// 首先声明定义我们需要的变量

let array = new Array(); // 一个有序数组
let left = 0; // 数组的左端点
let right = array.length - 1; // 数组的右端点
let find; // 我们需要查找的数
let middle; // 数组的中间数 

  定义的数组:

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

valiant小东

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值