benjamin.li的小屋

认真投入的做一件事情,让这件事情有结果

【剑指offer】和为S的两个数字

题目描述

输入一个递增排序的数组和一个数字S,在数组中查找两个数,是的他们的和正好是S,如果有多对数字的和等于S,输出两个数的乘积最小的。


数列满足递增,设两个头尾两个指针i和j,
若ai + aj == sum,就是答案(相差越远乘积越小)
若ai + aj > sum,aj肯定不是答案之一(前面已得出 i 前面的数已是不可能),j -= 1
若ai + aj < sum,ai肯定不是答案之一(前面已得出 j 后面的数已是不可能),i += 1
O(n)

# -*- coding:utf-8 -*-
class Solution:
    def FindNumbersWithSum(self, array, tsum):
        # write code here
        if not array:
            return []
        left = 0
        right = len(array)-1
        cur = array[left]+array[right]
        while cur != tsum and left < right:
            if cur < tsum:
                left += 1
            else:
                right -= 1
            cur = array[left]+array[right]
        if cur != tsum:
            return []
        else:
            return [array[left], array[right]]

阅读更多
版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/weixin_38111819/article/details/79949066
上一篇【剑指offer】和为S的连续正数序列
下一篇【剑指offer】左旋转字符串
想对作者说点什么? 我来说一句

没有更多推荐了,返回首页

关闭
关闭