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");
通过对比两种解法,我们可以看到哈希表解法在时间复杂度上有明显的优势,虽然牺牲了一定的空间复杂度,但在实际应用中通常是一个值得的选择。
热门推荐
科学饮食助癌症患者提升生活质量
癌症患者的心理咨询有多重要?
重大突破!华科协和医院参与研究证实:免疫联合放化疗显著提高鼻咽癌患者生存率
土地征收促经济增就业,但需警惕环境与社会稳定
千年古城襄阳免费开放,2800年文化遗存焕新颜
脂溢性皮炎这样调理:5类食物要避免,5类要多吃,5个生活好习惯
苏格兰风笛乐器:传统与价格的完美融合
苏格兰风笛文化:从历史传承到全球传播
无痕浏览真的能保护隐私吗?
从USB到蓝牙:手柄连接电脑的正确方式
macOS支持Xbox One/360手柄有线连接:第三方驱动安装详解
从PUA到NPD:如何识别和防范情感操控
PUA:从搭讪技巧到情感诈骗,如何保护自己
机器学习算法详解:让AI自我学习的核心技术
大胜41分!亚历山大闪耀,威金斯创纪录,雷霆崛起改写联盟格局
霍普菲尔德和辛顿获诺奖:用物理学工具革新机器学习
马尔代夫环境气候与主要岛屿分布
五味子对糖尿病的作用
从中医“五味”学养生,调养身体变简单
联合国糖尿病日特辑|增进“小糖人”幸福感,中医有办法!
中国EMBA教育:从萌芽到变革,数字化转型开启新篇章
眼睛被风一吹就流眼泪?别不当回事,可能是你的泪道出问题了!
为什么一到冬天,眼睛就容易「迎风流泪」?
在城区骑电动车一般不得载人,否则发生事故需担责!
口腔黏膜病的中药方剂治疗
33年寻亲路:从DNA比对到家庭融合的挑战
中药粉结块怎么办?中医生教你正确保存
古钱币清洗指南:6种方法让锈迹无处藏身
《红高粱》:张艺谋的成名之作与电影传奇
张艺谋《第二十条》:用喜剧讲述"正当防卫"的法治故事