leetcode 1. 两数之和

cpp 复制代码
class Solution {
public:
    vector<int> twoSum(vector<int>& nums, int target) {
        if(nums.size() == 2)
        return {0, 1};
        unordered_map <int, int> mapnums;
        for(int i = 0;i < nums.size();i++)
        {
            if(mapnums.count(target - nums[i]))
            {
               return {mapnums[target - nums[i]],i};
            }
            mapnums[nums[i]] = i;
        }
        return {-1,-1};
    }
};
  • 输入验证:

    • 首先,代码检查 nums 的大小是否为 2。如果是,则直接返回 {0, 1}。这是一个边界情况的处理,因为当数组只有两个元素时,它们必然是目标值的和。
  • 使用哈希表:

    • 接下来,代码创建了一个 unordered_map(无序映射)mapnums,用于存储数组中的每个元素及其对应的索引。
  • 遍历数组:

    • 使用一个 for 循环遍历数组 nums
    • 在每次迭代中,检查 mapnums 是否包含 target - nums[i] 这个键。这是基于这样一个事实:如果数组中存在两个数 ab,使得 a + b = target,那么对于数组中的任意一个数 a,另一个数 b 必然是 target - a
  • 找到匹配项:

    • 如果在 mapnums 中找到了 target - nums[i] 这个键,说明找到了两个数的和为 target。此时,返回这两个数的索引:mapnums[target - nums[i]]target - nums[i] 的索引)和 i(当前遍历到的 nums[i] 的索引)。
  • 更新哈希表:

    • 如果在 mapnums 中没有找到 target - nums[i],则将当前元素 nums[i] 和其索引 i 添加到 mapnums 中,以便在后续的迭代中进行查找。
  • 返回默认结果:

    • 如果循环结束后仍然没有找到和为 target 的两个数,则返回 {-1, -1},表示没有找到这样的两个数。
  • 这个算法的时间复杂度是 O(n),其中 n 是数组 nums 的大小。因为只需要遍历一次数组,而每次查找哈希表的操作都是 O(1) 的时间复杂度。这个算法非常高效,特别是当数组很大时。

相关推荐
闻缺陷则喜何志丹6 小时前
【SOSDP模板 容斥原理 逆向思考】3757. 有效子序列的数量|分数未知
c++·算法·力扣·容斥原理·sosdp·逆向思考
CoovallyAIHub6 小时前
如何在手机上轻松识别多种鸟类?我们发现了更简单的秘密……
深度学习·算法·计算机视觉
别动哪条鱼6 小时前
AVAudioFifo
数据结构·ffmpeg·音视频
第二只羽毛6 小时前
遵守robots协议的友好爬虫
大数据·爬虫·python·算法·网络爬虫
BestOrNothing_20156 小时前
一篇搞懂 C++ 重载:函数重载 + 运算符重载,从入门到会用(含 ++、<<、== 实战)
c++·函数重载·运算符重载·operator·前置后置++·重载与重写
艾斯比的日常6 小时前
Java 三色标记算法:并发垃圾回收的核心技术解析
java·开发语言·算法
2501_941144426 小时前
Python + C++ 异构微服务设计与优化
c++·python·微服务
CoovallyAIHub6 小时前
抛弃LLM!MIT用纯视觉方法破解ARC难题,性能接近人类水平
深度学习·算法·计算机视觉
程序猿编码7 小时前
PRINCE算法的密码生成器:原理与设计思路(C/C++代码实现)
c语言·网络·c++·算法·安全·prince
高洁017 小时前
具身智能-视觉语言导航(VLN)
深度学习·算法·aigc·transformer·知识图谱