热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

JavaScript搜索算法:线性查找、二分查找

线性查找functionLinerSearch(arr,target){设置目标元素位置letposition-1;letlenarr.length;for(leti0;i

线性查找

function LinerSearch(arr, target) {// 设置目标元素位置let position &#61; -1;let len &#61; arr.length;for (let i &#61; 0; i < len; i&#43;&#43;) {if (arr[i] &#61;&#61;&#61; target) {position &#61; i;return position;}}return position;
}console.log(&#39;LinerSearch&#39;, LinerSearch([4, 18, 5, 2, 9, 2], 9))

二分查找

function binarysearch(arr, target) {// 前提为有序数组if (Array.isArray(arr)) {let len &#61; arr.length; //数组长度let maxIndex &#61; len - 1;let minIndex &#61; 0;while (minIndex <&#61; maxIndex) {let midIndex &#61; Math.floor((maxIndex &#43; minIndex) / 2); //向下取整// 判断目标值与中间值比较if (target < arr[midIndex]) {// 重置设置最大值索引maxIndex &#61; midIndex - 1;} else if (target > arr[midIndex]) {minIndex &#61; midIndex &#43; 1} else if (target &#61;&#61;&#61; arr[midIndex]) {return arr[midIndex]}}// 查找失败return -1;}
}console.log(&#39;binarysearch&#39;, binarysearch([3, 6, 7, 15, 18, 19], 6));

二分查找递归实现

function recursionBinarySearch(arr, target, minIndex, maxIndex) {if (Array.isArray(arr)) {let len &#61; arr.length;let max &#61; maxIndex || len - 1;let min &#61; minIndex || 0;let midIndex &#61; Math.floor((max &#43; min) / 2)if (min > max) {return -1; //查找失败}if (target > arr[midIndex]) {min &#61; midIndex &#43; 1return recursionBinarySearch(arr, target, min, max)} else if (target < arr[midIndex]) {max &#61; midIndex - 1return recursionBinarySearch(arr, target, min, max)} else if (target &#61;&#61;&#61; arr[midIndex]) {return midIndex}}
}console.log(&#39;recursionBinarySearch&#39;, recursionBinarySearch([3, 6, 7, 15, 18, 19], 7))


推荐阅读
  • Ihavethefollowingonhtml我在html上有以下内容<html><head><scriptsrc..3003_Tes ... [详细]
  • 本文介绍了闭包的定义和运转机制,重点解释了闭包如何能够接触外部函数的作用域中的变量。通过词法作用域的查找规则,闭包可以访问外部函数的作用域。同时还提到了闭包的作用和影响。 ... [详细]
  • 本文介绍了在wepy中运用小顺序页面受权的计划,包含了用户点击作废后的从新受权计划。 ... [详细]
  • GetWindowLong函数
    今天在看一个代码里头写了GetWindowLong(hwnd,0),我当时就有点费解,靠,上网搜索函数原型说明,死活找不到第 ... [详细]
  • 目录实现效果:实现环境实现方法一:基本思路主要代码JavaScript代码总结方法二主要代码总结方法三基本思路主要代码JavaScriptHTML总结实 ... [详细]
  • 本文讨论了在Windows 8上安装gvim中插件时出现的错误加载问题。作者将EasyMotion插件放在了正确的位置,但加载时却出现了错误。作者提供了下载链接和之前放置插件的位置,并列出了出现的错误信息。 ... [详细]
  • 如何使用Java获取服务器硬件信息和磁盘负载率
    本文介绍了使用Java编程语言获取服务器硬件信息和磁盘负载率的方法。首先在远程服务器上搭建一个支持服务端语言的HTTP服务,并获取服务器的磁盘信息,并将结果输出。然后在本地使用JS编写一个AJAX脚本,远程请求服务端的程序,得到结果并展示给用户。其中还介绍了如何提取硬盘序列号的方法。 ... [详细]
  • Metasploit攻击渗透实践
    本文介绍了Metasploit攻击渗透实践的内容和要求,包括主动攻击、针对浏览器和客户端的攻击,以及成功应用辅助模块的实践过程。其中涉及使用Hydra在不知道密码的情况下攻击metsploit2靶机获取密码,以及攻击浏览器中的tomcat服务的具体步骤。同时还讲解了爆破密码的方法和设置攻击目标主机的相关参数。 ... [详细]
  • javascript  – 概述在Firefox上无法正常工作
    我试图提出一些自定义大纲,以达到一些Web可访问性建议.但我不能用Firefox制作.这就是它在Chrome上的外观:而那个图标实际上是一个锚点.在Firefox上,它只概述了整个 ... [详细]
  • Python正则表达式学习记录及常用方法
    本文记录了学习Python正则表达式的过程,介绍了re模块的常用方法re.search,并解释了rawstring的作用。正则表达式是一种方便检查字符串匹配模式的工具,通过本文的学习可以掌握Python中使用正则表达式的基本方法。 ... [详细]
  • 闭包一直是Java社区中争论不断的话题,很多语言都支持闭包这个语言特性,闭包定义了一个依赖于外部环境的自由变量的函数,这个函数能够访问外部环境的变量。本文以JavaScript的一个闭包为例,介绍了闭包的定义和特性。 ... [详细]
  • Html5-Canvas实现简易的抽奖转盘效果
    本文介绍了如何使用Html5和Canvas标签来实现简易的抽奖转盘效果,同时使用了jQueryRotate.js旋转插件。文章中给出了主要的html和css代码,并展示了实现的基本效果。 ... [详细]
  • 本文介绍了使用cacti监控mssql 2005运行资源情况的操作步骤,包括安装必要的工具和驱动,测试mssql的连接,配置监控脚本等。通过php连接mssql来获取SQL 2005性能计算器的值,实现对mssql的监控。详细的操作步骤和代码请参考附件。 ... [详细]
  • 本文介绍了获取关联数组键的列表的方法,即使用Object.keys()函数。同时还提到了该方法在不同浏览器的支持情况,并附上了一个代码片段供读者参考。 ... [详细]
  • 模板引擎StringTemplate的使用方法和特点
    本文介绍了模板引擎StringTemplate的使用方法和特点,包括强制Model和View的分离、Lazy-Evaluation、Recursive enable等。同时,还介绍了StringTemplate语法中的属性和普通字符的使用方法,并提供了向模板填充属性的示例代码。 ... [详细]
author-avatar
qyc_3830179
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有