营销型网站建设易网拓/电工培训内容
题目
给定一个整数数组 nums 和一个目标值 target,请你在该数组中找出和为目标值的那 两个 整数,并返回他们的数组下标。
你可以假设每种输入只会对应一个答案。但是,你不能重复利用这个数组中同样的元素。
示例:
给定 nums = [2, 7, 11, 15], target = 9
因为 nums[0] + nums[1] = 2 + 7 = 9
所以返回 [0, 1]
。
解法一:
暴力解法,两层循坏。
def twoSum(self, nums, target):""":type nums: List[int]:type target: int:rtype: List[int]"""i = 0ind = []for i in range(len(nums)):for j in range(i+1, len(nums)):if (target - nums[j]) == nums[i]:ind = [i, j]breakreturn ind
解法二:
生成字典,利用字典的get()
函数查找index
def twoSum(self, nums, target):# 生成字典dictt = {num:ind for ind, num in enumerate(nums)}ind = []for i in range(len(nums)):j = dictt.get(target-nums[i])if j is not None and i!=j:breakreturn [i,j]
解法三:
一层循坏搞定,寻找目标值与当前值的差值是否在数组的其余元素中。
def twoSum(self, nums, target):ind = 0for i in range(len(nums)):if (target - nums[i]) in nums[i+1:]:ind = nums.index(target - nums[i], i+1)breakreturn [i, ind]