题目描述
输入一个递增排序的数组和一个数字S,在数组中查找两个数,使得他们的和正好是S,如果有多对数字的和等于S,输出两个数的乘积最小的。输出描述:
对应每个测试案例,输出两个数,小的先输出。
思路
hash表
①将所有元素存储在hash表中
②key = 数字 value = 数组的索引
③遍历数组查询hash表中是否存在
hash表代码
// hash表
public class Solution {
public ArrayList FindNumbersWithSum_2(int[] array, int sum) {
ArrayList result = new ArrayList();
// 代码的鲁棒性
if (array == null || array.length < 2) {
return list;
}
// hash表
HashMap map = new HashMap();
int len = array.length;
for (int i = 0; i < len; i++) {
map.put(array[i], i);
}
for (int i = 0; i < len; i++) {
int sub = sum - array[i];
if (map.containsKey(sub)) {
result.add(array[i]);
result.add(sub);
break;
}
}
return result;
}
}
双指针
双指针代码
// 双指针
public class Solution {
public ArrayList<Integer> FindNumbersWithSum(int [] array, int sum) {
ArrayList<Integer> list = new ArrayList<>();
// 代码的鲁棒性
if (array == null || array.length < 2) {
return list;
}
int start = 0;
int end = array.length-1;
while (start < end){
if (array[start] + array[end] == sum){
list.add(array[start]);
list.add(array[end]);
break;
}else if (array[start] + array[end] > sum){
end--;
}else {
start++;
}
}
return list;
}
}
NowCoder(Online Coding, Please Click)