题解 | #三数之和#

三数之和

https://www.nowcoder.com/practice/345e2ed5f81d4017bbb8cc6055b0b711

#
# 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
#
# 
# @param num int整型一维数组 
# @return int整型二维数组
#
class Solution:
    def threeSum(self , num: List[int]) -> List[List[int]]:
        # write code here
        res = []
        n = len(num)
        num.sort()
        for i in range(n-2):
            if i != 0 and num[i] == num[i-1]:
                continue
            left = i + 1
            right = n - 1
            # # 三数之和等于0 == 两数之和等于另一个数
            target = -num[i]
            
            while left < right:
                if num[left] + num[right] == target:
                    res.append([num[i], num[left], num[right]])
                    # # 重复的值不用每次都判断,跳过就好
                    while left + 1 < right and num[left] == num[left+1]:
                        left += 1
                    while right - 1> left and num[right] == num[right - 1]:
                        right -= 1
                    # # 因为这三个数之和已经恰好等于0了,在去除重复值过后left和right两个都动
                    left += 1
                    right -= 1
                # # 三数之和大于了0,这个时候应该让右指针左移
                elif num[left] + num[right] > target:
                    right -= 1
                # # 三数之和小于了0,这个时候应该让左指针右移
                else:
                    left += 1
        return res
                        
                        
                        
                        
                        
                        

全部评论

相关推荐

矫健的闭门羹烹饪师又...:本人双非本,在鹅厂测开实习,你这个简历上写的这两个项目的技术栈都差不多,能够让面试官去延伸去问的八股除了redis就再没啥了,建议项目这边可以再改改,然后专业技能那块的话,感觉linux和测试工具可以分开写,毕竟不是干一件事的,反正没实习的基础上面试就深挖项目和八股,好好卷吧
听劝,我这个简历该怎么改...
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务