力扣——两数之和,三数之和

一、两数之和

题目:给定一个整数数组 nums 和一个整数目标值 target,请你在该数组中找出 和为目标值 target 的那 两个 整数,并返回它们的数组下标。

你可以假设每种输入只会对应一个答案。但是,数组中同一个元素在答案里不能重复出现。

你可以按任意顺序返回答案。

javascript 复制代码
var twoSum = function(nums, target) {
    let map={}
    for(let i=0;i<nums.length;i++){
        let curNum = nums[i];
        let targetName = target-curNum;
        let targetNameIndex = map[targetName];
        if(targetNameIndex!==undefined){
            return [targetNameIndex,i]
        }
        map[curNum]=i;
    }
    return null;
};
二、三数之和

题目:给你一个整数数组 nums ,判断是否存在三元组 [nums[i], nums[j], nums[k]] 满足 i != ji != kj != k ,同时还满足 nums[i] + nums[j] + nums[k] == 0 。请

你返回所有和为 0 且不重复的三元组。

**注意:**答案中不可以包含重复的三元组。

javascript 复制代码
var threeSum = function(nums) {
    let array=[];
    const len=nums.length;
    if(len<3) return [];
    nums.sort((a,b)=>a-b);
    for(let i=0;i<len;i++){
        // 如果三个数字当中第一个大于0,则和定不为0,结束for循环
        if(nums[i]>0) break;
        if(i>0&&nums[i]==nums[i-1]) continue;
        let l=i+1;
        let r=len-1;
        while(l<r){
            const sum = nums[i]+nums[l]+nums[r];
            if(sum==0){
                array.push([nums[i],nums[l],nums[r]]);
                // 去重,遇到和下一位相同的,直接跳到下一位
                while(l<r&&nums[l]==nums[l+1]) l++;
                while(l<r&&nums[r]==nums[r-1]) r--;
                l++;
                r--;
            }
            else if(sum<0) l++;
            else r--;
        }
    }
    return array;
};
相关推荐
我在人间贩卖青春4 分钟前
线性表之循环队列
数据结构·队列·循环队列
dragoooon347 分钟前
[C++——lesson29.数据结构进阶——「AVL树」]
算法
碧海银沙音频科技研究院11 分钟前
论文写作word插入公式显示灰色解决办法
人工智能·深度学习·算法
长沙京卓25 分钟前
【无人机算法】低空经济下无人机巡检检测识别算法(城市、林业、水利)
算法·无人机
hn小菜鸡26 分钟前
LeetCode 1971.寻找图中是否存在路径
算法·leetcode·职场和发展
Han.miracle34 分钟前
数据结构与算法--007三数之和(medium)
算法·leetcode·排序算法
听风吹等浪起37 分钟前
机器学习算法:随机梯度下降算法
人工智能·深度学习·算法·机器学习
落羽的落羽38 分钟前
【C++】哈希扩展——位图和布隆过滤器的介绍与实现
linux·服务器·开发语言·c++·人工智能·算法·机器学习
仁桃仁呀42 分钟前
160.相交链表
数据结构·算法·链表
普密斯科技44 分钟前
从点测量到解决方案:光谱共焦技术如何集成于运动平台,实现3D轮廓扫描与透明物体测厚?
人工智能·算法·计算机视觉·3d·集成测试·测量