题目描述
输入一个递增排序的数组和一个数字S,在数组中查找两个数,使得他们的和正好是S,如果有多对数字的和等于S,输出两个数的乘积最小的。
输出描述:
对应每个测试案例,输出两个数,小的先输出。
class Solution:
def FindNumbersWithSum(self, array, tsum):
# write code here
res = [float('-inf'),float('-inf')]
l,r = 0,len(array)-1
while l<r:
if array[l]+array[r]==tsum and array[l]*array[r]<res[0]*res[1]:
res[0],res[1] =array[l],array[r]
elif array[l]+array[r]<tsum:
l +=1
else:
r -=1
return res if res[0]!=float('-inf') else []