【LeetCode】1. 两数之和

题目

【LeetCode】1. 两数之和

思路

方法一:暴力解。先用size()求出数组长度,遍历两个for找出和为target的数组下标。如果找不到则返回{}。

方法二:哈希表。时间复杂度更低,但自己想不到。用unordered_map,与map的区别是unordered_map 容器不会像 map 容器那样对存储的数据进行排序。创建一个哈希表,对于每一个 x,我们首先查询哈希表中是否存在 target - x,然后将 x 插入到哈希表中,即可保证不会让 x 和自己匹配。

代码(暴力解)

cpp 复制代码
class Solution {
public:
    vector<int> twoSum(vector<int>& nums, int target) {
        int n=nums.size();
        for(int i=0;i<n;i++)
        {
            for(int j=i+1;j<n;j++)
            {
                if(nums[i]+nums[j]==target)
                {
                    return {i,j};
                }
            }
        }
        return {};
    }
};

代码(哈希)

cpp 复制代码
class Solution {
public:
    vector<int> twoSum(vector<int>& nums, int target) {
        unordered_map<int,int>table;
        for(int i=0;i<nums.size();i++)
        {
            auto it=table.find(target-nums[i]);
            if(it!=table.end())
            {
                return {it->second,i};
            }
            table[nums[i]]=i;
        }
        return {};
    }
};
相关推荐
生信宝典16 分钟前
机器学习算法 - 随机森林之决策树初探(1)
算法·随机森林·机器学习
计算机小白一个18 分钟前
蓝桥杯 Java B 组之函数定义与递归入门
java·算法·职场和发展·蓝桥杯
iOS开发的小学生1 小时前
国密算法SM1、SM2、SM3和SM4 具体的使用和区别
算法·国密加密·sm1 sm2 sm3 sm4
阑梦清川1 小时前
蓝桥杯---颜色分类(leetcode第75题)题解
leetcode·蓝桥杯
CodeJourney.2 小时前
DeepSeek关联PPT使用教程
数据库·人工智能·算法
xiaolin03333 小时前
146. LRU 缓存
算法·哈希·lru·双向链表
m0nesy_86803 小时前
1314--力扣情人节特别篇
java·算法·leetcode
MiyamiKK573 小时前
leetcode_二叉树 108. 将有序数组转换为二叉搜索树
算法·leetcode·职场和发展
Wang's Blog3 小时前
数据结构与算法之数组: LeetCode 541. 反转字符串 II (Ts版)
算法·leetcode