剑指 Offer 57. 和为s的两个数字

题目

输入一个递增排序的数组和一个数字s,在数组中查找两个数,使得它们的和正好是s。如果有多对数字的和等于s,则输出任意一对即可。

示例1:

1
2
输入:nums = [2,7,11,15], target = 9
输出:[2,7] 或者 [7,2]

示例2:

1
2
输入:nums = [10,26,30,31,47,60], target = 40
输出:[10,30] 或者 [30,10]

提示:

  • 1 <= nums.length <= 10^5
  • 1 <= nums[i] <= 10^6

解法

解法一:

JAVA

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
public int[] twoSum(int[] nums, int target) {
int begin = 0;
int end = nums.length - 1;
while (begin < end) {
int num = nums[begin] + nums[end];
if (num == target) {
return new int[]{nums[begin], nums[end]};
} else if (num < target) {
begin++;
} else {
end--;
}
}
return new int[]{-1, -1};
}
0%