LeetCode第一题详解:两数之和的暴力解法与哈希表优化
创作时间:
作者:
@小白创作中心
LeetCode第一题详解:两数之和的暴力解法与哈希表优化
引用
CSDN
1.
https://blog.csdn.net/2301_78566776/article/details/143580630
本文将为大家介绍LeetCode第一题“两数之和”的两种解法:暴力解法和哈希表解法。通过对比两种方法的时间复杂度和空间复杂度,帮助读者理解如何在实际编程中选择最优解。
题目描述
给定一个整数数组 nums 和一个整数目标值 target,请你在该数组中找出和为目标值 target 的那两个整数,并返回它们的数组下标。
你可以假设每种输入只会对应一个答案,并且你不能使用两次相同的元素。你可以按任意顺序返回答案。
示例:
方法一:暴力解法
暴力解法是最直观的解法,通过两个嵌套循环遍历数组中的每一个数,查看是否有与之对应的数使得二者之和为 target。
值得注意的是:每一个位于 x 之前的元素都已经和 x 匹配过,因此不需要再进行匹配。而每一个元素不能被使用两次,所以我们只需要在 x 后面的元素中寻找即可。(所以下面代码第二层循环的开始是 j=i+1)
class Solution {
public int[] twoSum(int[] nums, int target) {
for(int i=0;i<nums.length;i++){
for(int j=i+1;j<nums.length;j++){
if(nums[i]+nums[j]==target){
return new int[] {i,j};
}
}
}
return new int[] {};
}
}
- 时间复杂度:O(N^2),其中 N 是数组中的元素数量。
- 空间复杂度:O(1)。
方法二:哈希表解法
哈希表法体现了“空间换时间”的思想。在遍历的同时,记录一些信息,以省去一层循环。具体来说,需要记录已经遍历过的数值和它对应的下标,可以借助查找表实现。
查找表通常有:哈希表、平衡二叉搜索树。我们不需要维护所存数组的顺序性,使用哈希表即可。
图解说明
- 首先我们把第一个元素存入哈希表中,位置为0
- 此后将后续元素存入哈希表,存入前需要检查哈希表里有没有和它配对的元素,有的话返回这两个元素的下标,没有的话,将该元素存入哈希表。
- 哈希表的长度为len-1即可。
代码实现
class Solution {
public int[] twoSum(int[] nums, int target) {
int len=nums.length;
//初始化哈希表,要求规定其大小
Map<Integer,Integer>hashMap=new HashMap(len-1);
//存入第一个元素
hashMap.put(nums[0],0);
//其余元素循环遍历
for(int i=1;i<len;i++){
//定义另一个要在哈希表中寻找的元素
int another =target-nums[i];
//判断哈希表中是否存在
if(hashMap.containsKey(another)){
//如果存在,返回二者下标
return new int[]{i,hashMap.get(another)};
}else{
//不存在将该元素存入哈希表
hashMap.put(nums[i],i);
}
}
//任意返回
return new int[] {0};
}
}
注意:根据题目规定,代码是不会执行到 return new int[] {0}; 这一行的。所以我们可以返回任意值。当然我们也可以抛回一个异常:
throw new IllegalArgumentException("No two sum solution");
通过对比两种解法,我们可以看到哈希表解法在时间复杂度上有明显的优势,虽然牺牲了一定的空间复杂度,但在实际应用中通常是一个值得的选择。
热门推荐
后羿在中国古代神话中的地位与影响
后羿与羿:历史上的两位不同英雄
家中风水如何使夫妻关系和谐
用这款APP举报酒驾,你就是城市英雄!
如何有效举报酒驾?这份指南请收好
酒驾举报:你真的了解吗?
年轻人,你为什么脱发?拿什么拯救你的头发
王进和史进:水浒传里的命运密码
从王进和史进看宋朝兴衰
上海新能源汽车保有量全球城市第一
管道工程中的直径表示方法:DN、De、D、d、Φ的区别与对应关系
韦达定理的图形解析:一元二次方程根的直观理解
“智能手环”骗局曝光:200万人被骗,涉案8000万,最小诈骗29元
春节防骗指南:微信诈骗套路大揭秘
微信贷款诈骗高发!用AI护航你的钱袋子
广东省中医院二沙岛医院:智慧医疗与中医特色并重的三级甲等医院
广东省中医院二沙岛医院:社区健康教育的创新实践
收视逆袭跳涨,《无所畏惧2》为何成为观众心头好?
智能库存管理:防护面罩工厂的转型升级之道
秋冬雾霾季,你的防护面罩用对了吗?
眼视物模糊的中药方剂是什么
小米手机网络设置详解:Wi-Fi、移动网络、网络优化全攻略
德国动物园扑杀园中一半狒狒,喂给掠食者?为何敢称此举能保护种群
五部高分音乐电影,感受不一样的视听之旅
赵括:被误解的将领?
赵括:历史评价与军事才能的探讨
赵括:被误解的将领?
长平之战中的决策变局:赵括替代廉颇的背后
柴胡疏肝汤:疏肝解郁,行气止痛的经典方剂
声临其境!《哪吒2》配音天团背后的热血故事