题目描述
输入一个递增排序的数组和一个数字S,在数组中查找两个数,使得他们的和正好是S,如果有多对数字的和等于S,输出两个数的乘积最小的。
输出描述:
对应每个测试案例,输出两个数,小的先输出。
思路:
1、双指针i,j, i, j = 0, length - 1
2、指针指向的元素和与tsum对比:
如果array[i] + array[j] < tsum,坐指针右移 i += 1;
array[i] + array[j] > tsum,右指针左移 j -= 1;
array[i] + array[j] = tsum,将两数的乘积,和两个数组成的列表存储到词典中,dic[array[i] * array[j]] = [array[i], array[j]]
3、根据词典key的最小值获取对应的两个数
python2.7解法:
# -*- coding:utf-8 -*-
class Solution:
def FindNumbersWithSum(self, array, tsum):
# write code here
length = len(array)
if length < 2:
return []
dic = {}
i, j = 0, length - 1
while i <= j:
if array[i] + array[j] < tsum:
i += 1
elif array[i] + array[j] > tsum:
j -= 1
else:
dic[array[i] * array[j]] = [array[i], array[j]]
i += 1
j -= 1
return dic[min(dic.keys())] if dic else []
网友评论