糖尿病康复,内容丰富有趣,生活中的好帮手!
糖尿病康复 > 代码随想录一一一哈希表一一一三数之和

代码随想录一一一哈希表一一一三数之和

时间:2019-10-08 05:24:40

相关推荐

代码随想录一一一哈希表一一一三数之和

题目来源自leetcode与代码随想录

(1)15.三数之和

题目描述:

给你一个包含 n 个整数的数组 nums,判断 nums 中是否存在三个元素 a,b,c ,使得 a + b + c = 0 ?请你找出所有和为 0 且不重复的三元组。

解题思路:

双指针 定一寻二

剪枝

1使用排序后第一个值来确定,最小值大于0则结束

2为避免出现重复情况

while left < right and nums[left] == nums[left+1]

while left < right and nums[right] == nums[right-1]

class Solution:def threeSum(self, nums: List[int]) -> List[List[int]]:L = len(nums)if L <= 2:return []res = []nums.sort()for i in range(L):if nums[i] > 0:breakif i > 0 and nums[i] == nums[i-1]:continueleft = i + 1right = L - 1while left < right:tempSum = nums[i] + nums[left] + nums[right]if tempSum == 0:res.append( [nums[i], nums[left], nums[right]] )while left < right and nums[left] == nums[left+1]:left += 1while left < right and nums[right] == nums[right-1]:right -= 1left += 1right -= 1elif tempSum < 0:left += 1elif tempSum > 0:right -= 1else:passreturn res

如果觉得《代码随想录一一一哈希表一一一三数之和》对你有帮助,请点赞、收藏,并留下你的观点哦!

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。