题目描述
输入一个递增排序的数组和一个数字S,在数组中查找两个数,是的他们的和正好是S,如果有多对数字的和等于S,输出两个数的乘积最小的。
思路:这题有个十分简单的思路,也是我一开始想到的思路。也就是定义两个指针,指针i位于数组的开始,指针j位于数组的结尾,当array[i]+array[j]<sum时,i++,当array[i]+array[j]>sum时,j--。当array[i]+array[j]==sum时,得到想要的结果。(不必纠结乘积最小,当i与j的差越大时,乘积就越小,当i与j越靠近时,乘积就越大,所以第一个找到的i与j就是想要的结果)
代码:
import java.util.*;
public class Solution {
public ArrayList<Integer> FindNumbersWithSum(int [] array,int sum) {
int size = array.length;
ArrayList<Integer> list = new ArrayList<Integer>();
for(int i=0,j=size-1;i<j;){
if(array[i]+array[j]<sum){
i++;
}
if(array[i]+array[j]>sum){
j--;
}
if(array[i]+array[j]==sum){
list.add(array[i]);
list.add(array[j]);
return list;
}
}
return list;
}
}