-
Notifications
You must be signed in to change notification settings - Fork 25
/
Copy pathTwo Sum II - Input array is sorted.java
executable file
·67 lines (54 loc) · 1.77 KB
/
Two Sum II - Input array is sorted.java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
M
1516439332
tags: Array, Two Pointers, Binary Search
升序array, 找2SUM.
#### Two pointers
- 排序好的array. Two pointer移动start和end,核查sum.
- 注意sum用long.
- O(n) time
#### Binary Search, 因为已经排好序了啊
- 定住一个valueA, 然后在剩下的里面 binary serach 找 (target - valueB)
- for loop O(n), binary search O(logn)
- overall time: O(nLogN), 就不写了
```
/*
Given an array of integers that is already sorted in ascending order,
find two numbers such that they add up to a specific target number.
The function twoSum should return indices of the two numbers such that they add up to the target,
where index1 must be less than index2.
Please note that your returned answers (both index1 and index2) are not zero-based.
You may assume that each input would have exactly one solution.
Input: numbers={2, 7, 11, 15}, target=9
Output: index1=1, index2=2
Tags: Array Two Pointers, Binary Search
Similar Problems: (M) Two Sum
*/
/*
Thoughts:
Two pointer sweeping.
Start, end. Check if nums[start] + nums[end] == target.
*/
class Solution {
public int[] twoSum(int[] numbers, int target) {
if (numbers == null || numbers.length == 0) {
return numbers;
}
final int[] result = new int[2];
int start = 0;
int end = numbers.length - 1;
while (start < end) {
long sum = (long)(numbers[start] + numbers[end]);
if (sum == target) {
result[0] = start + 1;
result[1] = end + 1;
break;
} else if (sum < target) {
start++;
} else {
end--;
}
}//end while
return result;
}
}
```