点上方蓝字计算机视觉联盟获取更多干货
在右上方 ··· 设为星标 ★,与你不见不散
LeetCode题目
给定一个整数数组 nums 和一个目标值 target,请你在该数组中找出和为目标值的那两个整数,并返回他们的数组下标。
你可以假设每种输入只会对应一个答案。但是,你不能重复利用这个数组中同样的元素。
示例:
给定 nums = [2, 7, 11, 15], target = 9
因为 nums[0] + nums[1] = 2 + 7 = 9
所以返回 [0, 1]
LeetCode解题记录
题目解析:
本题是需要求解数组中两个数之和为目标值的下标,作为LeetCode题目来说,本道题目是非常简单的,两种思路:
(1)最简单暴力法
双重循环,依次找出两个数求和,并找到两数之和与目标值相等的数的下标,时间复杂度为O(N^2)。
具体过程:
依次遍历数组的两个数,num1,num2
比较两数之和与目标值是否相等:num1+num2==target,相等则返回两个数的下标;无值则返回空值。
(2)哈希表
遍历数组 nums[i](i为下标值),判断map中是否存在key值:target-nums[i]
如果不存在则将将当前的num[i]存入map中的key值,i存入map的value值,继续遍历数组直到找到为止或者遍历完整个数组;如果存在,则返回map中key值的value值和当前num[i]值的i值。
具体过程如下图所示:
遍历第一个元素:
遍历第二个元素:
遍历第三个元素:
遍历第四个元素:
C++版本(简单暴力法):
class Solution {
public:
vector<int> twoSum(vector<int>& nums, int target)
{
int size=nums.size();
vector<int> None{0};
vector<int> index;
for(int i=0;i<size-1;++i)
for(int j=i+1;j<size;++j)
{
int sum=0;
sum=nums[i]+nums[j];
if(sum==target)
{
index=vector<int>({i,j});
return index;
}
}
return None;
}
};
C++版本(哈希表):
class Solution {
public:
vector<int> twoSum(vector<int>& nums, int target)
{
//提供一对一的hash
map<int,int> a_map;
//用来存储找到的结果下标,初始化一个大小为2,值为0的容器b
vector<int> b(2,0);
int size=nums.size();
for(int i=0;i<size;++i)
{
if(a_map.count(target-nums[i])>0)
{
b[0]=a_map[target-nums[i]];
b[1]=i;
break;
}
a_map[nums[i]]=i;//反过来放入map中,用来获取结果下标
}
return b;
};
};
END
加群交流
欢迎加入CV联盟LeetCode交流群,我们一起成长!
扫描添加CV联盟微信拉你进群,备注:CVLeetCode
带你自学Python专栏
带你自学Python系列(一):变量和简单数据类型(附思维导图)
带你自学Python系列(二):Python列表总结-思维导图
带你自学Python系列(四):range、min、max、sum函数
带你自学Python系列(五):Python解决列表字符不区分大小写问题
带你自学Python系列(九):一文读懂Python中字典应用原理!
带你自学Python系列(十一):Python函数的用法(一)
带你自学Python系列(十二):Python函数的用法(二)
带你自学Python系列(十三):Python函数的用法(三)
带你自学Python系列(十四):Python函数的用法(四)
带你自学Python系列(十五):Python中类的用法(一)
带你自学Python系列(十六):Python中类的用法(二)
带你自学Python系列(十七):Python中类的用法(三)
带你自学Python系列(十八):Python中类的用法(四)
带你自学Python系列(十九):Python读取文件详解
点个在看支持一下吧