我是靠谱客的博主 沉静可乐,最近开发中收集的这篇文章主要介绍leetCode解题--两数之和(python),觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

题目

给定一个整数数组和一个目标值,找出数组中和为目标值的两个数。
你可以假设每个输入只对应一种答案,且同样的元素不能被重复利用。

示例

给定 nums = [2, 7, 11, 15], target = 9

因为 nums[0] + nums[1] = 2 + 7 = 9
所以返回 [0, 1]

代码

def twoSum(self, nums, target):

    nums_bak = nums.copy()

    nums.sort()

    i = 0

    j = 0

    for k in range(0, (len(nums) - 1)):

        if nums[k] + nums[k + 1] >= target:

            i = k

            j = k + 1

            break

    while i >= 0 and j < len(nums):

        if nums[i] + nums[j] < target:

            j += 1

        elif nums[i] + nums[j] > target:

            i -= 1

        else:

            if nums[i] == nums[j]:

                return [nums_bak.index(nums[i]), nums_bak.index(nums[j], i + 1)]

            else:

                return [nums_bak.index(nums[i]), nums_bak.index(nums[j])]

最后

以上就是沉静可乐为你收集整理的leetCode解题--两数之和(python)的全部内容,希望文章能够帮你解决leetCode解题--两数之和(python)所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(33)

评论列表共有 0 条评论

立即
投稿
返回
顶部