leetcode 1 两数之和

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

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

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

利用哈希表查找效率完成优化

思路:在进行迭代并将元素插入到表中的同时,我们还会回过头来检查表中是否已经存在当前元素所对应的目标元素。如果它存在,那我们已经找到了对应解,并立即将其返回。

时间复杂度: O(n)

空间复杂度: O(n)

cs 复制代码
public class Solution {
    public int[] TwoSum(int[] nums, int target) {
        Dictionary<int,int> dic = new Dictionary<int,int>();
        for(int i = 0; i < nums.Length; i++)
        {
            int ans = target - nums[i];
            if(dic.ContainsKey(ans) && dic[ans] != i)
            {
                return new int[] { i, dic[ans] };
            }
            if( !dic.ContainsKey(nums[i]) )
                dic.Add(nums[i],i);
        }
        return new int[] { 0, 0 };
    }
}
相关推荐
Savior`L几秒前
字符串哈希
c++·算法·哈希算法·散列表
啊阿狸不会拉杆2 分钟前
《数字图像处理》实验3-频率域处理方法
图像处理·人工智能·算法·计算机视觉·数字图像处理
代码游侠7 分钟前
应用——HTTP天气查询
网络·笔记·网络协议·算法·http
智航GIS12 分钟前
6.1 for循环
开发语言·python·算法
爱学大树锯15 分钟前
353 · 最大字母」
算法
YGGP16 分钟前
【Golang】LeetCode 416. 分割等和子集
算法·leetcode
wjykp20 分钟前
part4 反向传播算法(BP算法)
人工智能·算法·机器学习
AndrewHZ21 分钟前
【图像处理基石】图像处理领域还有哪些核心挑战与难题?
图像处理·人工智能·算法·计算机视觉·噪声·图像增强·画质增强
啊阿狸不会拉杆21 分钟前
《数字图像处理》实验8-图像识别与分类
图像处理·人工智能·算法·分类·数据挖掘·数字图像处理
月明长歌25 分钟前
【码道初阶】Leetcode138:随机链表的复制:用 HashMap 做深拷贝的标准解法
java·数据结构·算法·leetcode·链表·哈希算法