栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Python

两数之和-python

Python 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

两数之和-python

class Solution:
    # 排序 + 双指针
    def twoSum1(self, nums, target):
        n = len(nums)
        # 升序
        nums.sort()
        # 声明双指针索引
        l = 0
        r = len(nums) - 1
        while (l < r):
            if (nums[l] + nums[r] < target):
                l = l + 1
            elif (nums[l] + nums[r] > target):
                r = r - 1
            else:
                return [l, r]
        return []

    # 空间换时间  先把出现的值进行预存  然后target - nums[i]看是否有预存的值  有的话就符合要求了  取出
    def twoSum2(self, nums, target):
        n = len(nums)
        mapper = {}
        for i in range(n):
            if (target - nums[i] in mapper):
                return [mapper[target - nums[i]], i]
            else:
                mapper[nums[i]] = i
        return []


a = Solution()
print(a.twoSum1([1, 2, 11, 2, 3, 7, 15], 9))
转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/461603.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号