leetcode专题训练 47. Permutations II

1.最开始用的方法,在上一题的基础之上加入了最后的去重判断,还加入了如果当前数和要换的数一样,就不更换的剪枝。但这个方法没有考虑到当前数和两个相同的数更换时的剪枝,所以耗时还是有点长。

class Solution:
    def permuteUnique(self, nums: List[int]) -> List[List[int]]:

        def BackTrack(first = 0):
            if first == l:
                if nums not in result:
                    result.append(nums[:])
            for i in range(first, l):
                if i == first or nums[i] != nums[first]:
                    nums[i], nums[first] = nums[first], nums[i]
                    BackTrack(first+1)
                    nums[i], nums[first] = nums[first], nums[i]
        
        l = len(nums)
        result = []
        BackTrack()
        return result
            
            

2.之后加入了上一种方法中没有的剪枝判断。而且这个剪枝步骤更简洁,只要当前数和上一个数相同,那么就直接剪枝。

import copy

class Solution:
    def permuteUnique(self, nums: List[int]) -> List[List[int]]:

        def BackTrack(nums, tmp = []):
            if not nums:
                result.append(tmp[:])
                return
            for i in range(len(nums)):
                if i != 0 and nums[i] == nums[i-1]:
                    continue
                BackTrack(nums[:i]+nums[i+1:], tmp+[nums[i]])
        
        l = len(nums)
        nums.sort()
        result = []
        BackTrack(nums)
        return result
            
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值