美文网首页
和为S的两个数字

和为S的两个数字

作者: 周英杰Anita | 来源:发表于2020-05-08 15:08 被阅读0次

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

相关文章

  • 和为S的两个数字

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

  • 和为S的两个数字

    题目描述 输入一个递增排序的数组和一个数字S,在数组中查找两个数,是的他们的和正好是S,如果有多对数字的和等于S,...

  • 和为S的两个数字

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

  • 和为S的两个数字

    题目描述 输入一个递增排序的数组和一个数字S,在数组中查找两个数,使得他们的和正好是S,如果有多对数字的和等于S,...

  • 和为S的两个数字

    题目描述输入一个递增排序的数组和一个数字S,在数组中查找两个数,使得他们的和正好是S,如果有多对数字的和等于S,输...

  • 和为S的两个数字

    题目描述 输入一个递增排序的数组和一个数字S,在数组中查找两个数,使得他们的和正好是S,如果有多对数字的和等于S,...

  • 和为S的两个数字

    时间限制:1秒 空间限制:32768K 题目描述 输入一个递增排序的数组和一个数字S,在数组中查找两个数,使得他们...

  • 和为S的两个数字

    题目描述 输入一个递增排序的数组和一个数字S,在数组中查找两个数,使得他们的和正好是S,如果有多对数字的和等于S,...

  • 和为s的两个数字

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

  • 和为s的两个数字

    题目链接 :https://leetcode.cn/problems/he-wei-sde-liang-ge-sh...

网友评论

      本文标题:和为S的两个数字

      本文链接:https://www.haomeiwen.com/subject/auufnhtx.html