001twoSum

泪湿孤枕 提交于 2020-04-05 14:56:04

刚开始无脑双重循环,虽然通过了,但是效率太低
看了题解后转用map,效率大幅提高

/**
 * @param {number[]} nums
 * @param {number} target
 * @return {number[]}
 */
var twoSum = function(nums, target) {
    let length = nums.length
    let mp = new Map()
    nums.forEach((d,i)=>{
        mp.set(d,i)
    })
    for(let i=0;i!=length;i++)
    {
        let j = mp.get(target-nums[i])
        if(j!=undefined && i!=j)
            return [i,j]
    }
};
标签
易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!