js中,什么是线性查找?

在 JavaScript 中,线性查找 (Linear Search),也叫顺序查找 ,是一种最简单、最直接的查找算法。它的基本思想是:从数组(或列表)的第一个元素开始,逐个检查每个元素,直到找到目标值或遍历完整个数组为止

特点:

  • 时间复杂度
    • 最好情况:O(1)(第一个元素就是要找的)
    • 最坏情况:O(n)(目标在最后一个位置,或者不存在)
    • 平均情况:O(n)
  • 空间复杂度:O(1)(不需要额外空间)
  • 不要求数组有序,适用于任何类型的数组

示例代码(JavaScript):

javascript 复制代码
function linearSearch(arr, target) {
  for (let i = 0; i < arr.length; i++) {
    if (arr[i] === target) {
      return i; // 返回目标元素的索引
    }
  }
  return -1; // 未找到,返回 -1
}

// 使用示例
const numbers = [10, 25, 3, 47, 15];
console.log(linearSearch(numbers, 3));  // 输出: 2
console.log(linearSearch(numbers, 100)); // 输出: -1

适用场景:

  • 数据量较小
  • 数组未排序
  • 只需要查找一次(如果多次查找,建议先排序后用二分查找等更高效方法)

总结:

线性查找虽然效率不高,但实现简单、通用性强,是理解查找算法的基础。在 JavaScript 中,原生方法如 Array.prototype.indexOf()Array.prototype.find()Array.prototype.findIndex() 内部本质上也是线性查找。

相关推荐
六月June June3 小时前
自定义调色盘组件
前端·javascript·调色盘
SY_FC4 小时前
实现一个父组件引入了子组件,跳转到其他页面,其他页面返回回来重新加载子组件函数
java·前端·javascript
糟糕好吃4 小时前
我让 AI 操作网页之后,开始不想点按钮了
前端·javascript·后端
陈天伟教授4 小时前
人工智能应用- 天文学家的助手:08. 星系定位与分类
前端·javascript·数据库·人工智能·机器学习
VaJoy4 小时前
给到夯!前端工具链新标杆 Vite Plus 初探
前端·vite
小彭努力中6 小时前
191.Vue3 + OpenLayers 实战:可控化版权信息(Attribution)详解与完整示例
前端·javascript·vue.js·#地图开发·#cesium
奇舞精选6 小时前
用去年 github 最火的 n8n 快速实现自动化推送工具
前端·agent
奇舞精选6 小时前
实践:如何为智能体推理引入外部决策步骤
前端·agent
无限大66 小时前
AI实战02:一个万能提示词模板,搞定90%的文案/设计/分析需求
前端·后端
朝阳5817 小时前
控制 Nuxt 页面的渲染模式:客户端 vs 服务端渲染
前端·javascript