题目描述:

解法1:
这种解法是通过HashSet去解决它。道理很简单,遍历数组,因为题目说两个数相加等于target,那我就把target减去每个数剩下值存入set中。每次存入时先判断set是否已经有存在这个数,如果有,则证明在这个数之前,有一个数和现在的数相加等于target。那么返回一个包含这两个数的数组即可。但是这种方法效率不高。
class Solution {
public int[] twoSum(int[] nums, int target) {
Set<Integer> set = new HashSet<>();
int[] res = new int[2];
for(int i = 0; i < nums.length; i++){
if(set.contains(nums[i])) {
res[0] = nums[i]; res[1] = target - nums[i];
}
else set.add(target - nums[i]);
}
return res;
}
}

解法2:
这种解法是通过双指针去解决这道题。首先我们定义双指针,一个在数组头,一个在数组尾。通过while循环,比较两个指针的元素和以及target,如果比target大,那么尾指针就向后移;如果比target小,头指针就向后移;只要头尾指针不相碰,就一直循环下去。当循环中,发现两指针的元素和等于target时,返回包含两指针元素的数组即可。
class Solution {
public int[] twoSum(int[] nums, int target) {
int[] res = new int[2];
int i = 0, j = nums.length - 1;
while(i < j) {
int s = nums[i] + nums[j];
if(s < target) i++;
else if(s > target) j--;
else{
res[0] = nums[i]; res[1] = nums[j]; return res;
}
}
return res;
}
}

本文深入探讨了经典的两数之和问题的两种高效解法:利用HashSet实现的单次遍历方法和采用双指针技术的有序数组求解策略。详细介绍了每种方法的实现原理和代码示例,帮助读者理解并掌握算法细节。

被折叠的 条评论
为什么被折叠?



