【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 {};
    }
};
相关推荐
百渡ovO9 分钟前
【蓝桥杯】十五届省赛B组c++
数据结构·c++·算法
梭七y19 分钟前
【力扣hot100题】(072)柱状图中的最大矩阵
算法·leetcode·职场和发展
Dovis(誓平步青云)20 分钟前
【数据结构】排序算法(下篇·开端)·深剖数据难点
c语言·数据结构·学习·算法·排序算法·推荐算法
浪漫血液&33 分钟前
OJ--第N个泰波那契数列
算法·动态规划
独好紫罗兰34 分钟前
洛谷题单3-P1307 [NOIP 2011 普及组] 数字反转-python-流程图重构
开发语言·python·算法
2301_7890156238 分钟前
算法与数据结构线性表之栈和队列
数据结构·算法
ん贤41 分钟前
2022第十三届蓝桥杯大赛软件赛省赛C/C++ 大学 B 组(题解&解析)
c语言·数据结构·c++·算法·蓝桥杯
流星白龙42 分钟前
【C++算法】49.分治_归并_计算右侧小于当前元素的个数
c++·算法
杭州的平湖秋月1 小时前
用 C++ 写汉诺塔程序
c++·算法
烁3473 小时前
每日一题(小白)模拟娱乐篇13
java·算法·娱乐·暴力