LeetCode 3Sum

class Solution(object):
    def threeSum(self, nums):
        """
        :type nums: List[int]
        :rtype: List[List[int]]
        """
        if nums is None:
            return []
        len_nums = len(nums)
        if len_nums < 3:
            return []
        nums.sort()

        list_result = []
        index_st = 0
        index_end = len_nums - 1

        index_fix = 0
        while(index_fix<len_nums):
            if index_fix != 0 and (nums[index_fix-1] == nums[index_fix]):
                index_fix += 1
                continue

            index_st = index_fix + 1
            index_end = len_nums - 1

            while(index_st<index_end):
                    sum = nums[index_st]+nums[index_end]+nums[index_fix]

                    if sum == 0:
                       list_result.append([nums[index_st],nums[index_fix],nums[index_end]])
                       stnum = nums[index_st]
                       ednum = nums[index_end]
                       while(nums[index_st]==stnum and index_st<index_end):
                           index_st += 1
                       while(nums[index_end]==ednum and index_end>index_st):
                           index_end -= 1
                    elif sum > 0:
                        index_end -= 1
                    else:
                        index_st += 1

            index_fix += 1
        return list_result

Runtime: 184 ms

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值