哈希表系列一>两数之和
题目:
链接: link
方法:
暴力代码:
代码语言:javascript代码运行次数:0运行复制public int[] twoSum(int[] nums, int target) {
解法一:暴力解法:
int n = nums.length;
for(int i = 1; i <= n; i++)
for(int j = i-1; j >= 0; j--){
if(target == nums[i] + nums[j]){
return new int[]{i,j};
}
}
return null;
}
优化后代码:
代码语言:javascript代码运行次数:0运行复制class Solution {
//解法二:用哈希表优化:
Map<Integer,Integer> hash = new HashMap<>();//<nums[i],i>
for(int i = 0; i < nums.length; i++){
int find = target - nums[i];
if(hash.containsKey(find)){
return new int[]{i,hash.get(find)};
}
hash.put(nums[i],i);
}
return null;
}
}
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。 原始发表:2025-04-03,如有侵权请联系 cloudcommunity@tencent 删除returntarget优化hashint