剑指offer 42.知识迁移能力 和为S的两个数字
题目描述
输入一个递增排序的数组和一个数字S,在数组中查找两个数,使得他们的和正好是S,如果有多对数字的和等于S,输出两个数的乘积最小的。
输出描述
对应每个测试案例,输出两个数,小的先输出。解题思路
先用两个for循环,找出数组中和为sum的两个数字对,并把他们一个作为key,一个作为value添加进一个Map<Integer,Integer>中,然后再遍历Map,得到乘积最小的数字对,添加进ArrayList中。
代码如下
public ArrayList<Integer> FindNumbersWithSum(int [] array,int sum) { Map<Integer, Integer> map=new HashMap<Integer, Integer>(2); ArrayList<Integer> list=new ArrayList<Integer>(); for (int i = 0; i < array.length; i++) { int tmp=array[i]; for (int j = i+1; j < array.length; j++) { if (array[i]+array[j]==sum) { map.put(array[i], array[j]); }else if (array[i]+array[j]>sum) { break; } } } int min=Integer.MAX_VALUE; for (Entry<Integer, Integer> m:map.entrySet()) { if (m.getKey()*m.getValue()<min) { min=m.getKey()*m.getValue(); list.add(0, m.getKey()); list.add(1, m.getValue()); }; } return list; }