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

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/weixin_38111819/article/details/79949066

题目描述

输入一个递增排序的数组和一个数字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]]

阅读更多
想对作者说点什么?

博主推荐

换一批

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