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 };
    }
}
相关推荐
我有一些感想……1 分钟前
An abstract way to solve Luogu P1001
c++·算法·ai·洛谷·mlp
前端小L2 分钟前
双指针专题(三):去重的艺术——「三数之和」
javascript·算法·双指针与滑动窗口
在风中的意志6 分钟前
[数据库SQL] [leetcode] 2388. 将表中的空值更改为前一个值
数据库·sql·leetcode
智者知已应修善业1 小时前
【求等差数列个数/无序获取最大最小次大次小】2024-3-8
c语言·c++·经验分享·笔记·算法
还不秃顶的计科生1 小时前
LeetCode 热题 100第二题:字母易位词分组python版本
linux·python·leetcode
LYFlied1 小时前
【每日算法】LeetCode 416. 分割等和子集(动态规划)
数据结构·算法·leetcode·职场和发展·动态规划
多米Domi0112 小时前
0x3f 第19天 javase黑马81-87 ,三更1-23 hot100子串
python·算法·leetcode·散列表
坚持学习前端日记2 小时前
软件开发完整流程详解
学习·程序人生·职场和发展·创业创新
历程里程碑2 小时前
滑动窗口最大值:单调队列高效解法
数据结构·算法·leetcode
課代表2 小时前
从初等数学到高等数学
算法·微积分·函数·极限·导数·积分·方程