js手写题:第二章

文章目录

前言

hello world欢迎来到前端的新世界


😜当前文章系列专栏:前端面试

🐱‍👓博主在前端领域还有很多知识和技术需要掌握,正在不断努力填补技术短板。(如果出现错误,感谢大家指出)🌹

💖感谢大家支持!您的观看就是作者创作的动力

题目要求

用js实现给定一个整数数组nums和一个证书目标值target,请你在该数组中找出和为目标值,target的那两个整数,并返回它们的数组下标,你可以假设没中输入只会对应一个答案,但是数组中见的一个元素在答案里不能重复出现,你可以按照任意顺序返回答案,用js实现,

加分项 :要求算法复杂度小于O(n2)

代码

可以使用哈希表来优化算法,在遍历原数组的同时,将元素存入哈希表中,同时判断哈希表中是否已经存在某个元素与当前元素能够组合成target,如果有,则直接返回结果即可。

javascript 复制代码
function twoSum(nums, target) {
  const map = new Map(); // 声明哈希表

  for (let i = 0; i < nums.length; i++) {
    const complement = target - nums[i];
    if (map.has(complement)) {
      return [map.get(complement), i];
    }
    map.set(nums[i], i); // 将元素存入哈希表中
  }
}

在空间使用上,我们可以优化掉哈希表和数组的使用,而是用单次循环来查找差值的时候同时将元素和索引记录在同一个 Map 中,就可以达到只遍历一次数组的时间复杂度,同时又不需要额外的空间开销。

javascript 复制代码
function twoSum(nums, target) {
  const map = new Map();

  for (let i = 0; i < nums.length; i++) {
    const complement = target - nums[i];
    if (map.has(complement)) {
      return [map.get(complement), i];
    }
    map.set(nums[i], i);
  }
}

后言

创作不易,要是本文章对广大读者有那么一点点帮助 不妨三连支持一下,您的鼓励就是博主创作的动力

相关推荐
大圣编程1 小时前
Python中continue语句的用法是什么?
开发语言·前端·python
upgrador1 小时前
基础知识:C++ STL构造函数的左闭右开惯例及其实现原理
开发语言·c++
之歆2 小时前
Vue商品详情与放大镜组件
前端·javascript·vue.js
yoothey2 小时前
报废审批流规则引擎设计——责任链模式完整实现
linux·开发语言·bash
geovindu3 小时前
python: Functional Options Pattern
开发语言·后端·python·设计模式·惯用法模式·函数式选项模式
wuyk5553 小时前
24. C 语言模块化:不是拆几个.c 文件那么简单
c语言·开发语言·stm32·单片机
凯瑟琳.奥古斯特3 小时前
K次取反最大化数组和解法(力扣1005)
开发语言·c++·算法·leetcode·职场和发展
AC赳赳老秦4 小时前
防火墙规则批量配置实战:OpenClaw 自动生成模板、批量下发与合规性校验全解析
java·开发语言·人工智能·python·github·php·openclaw
☆cwlulu4 小时前
调试排查工具介绍(gdb、strace、Valgrind等)
开发语言·c++·嵌入式硬件·ubuntu
C语言小火车4 小时前
C++ 快速排序(Quick Sort)深度精讲:分治思想、Lomuto 分区法及三数取中优化,面试手撕必会
c语言·开发语言·c++·面试·排序算法·快速排序