Leetcode

46. Permutations

2016-07-30  本文已影响14人  oo上海

46. Permutations

题目:
https://leetcode.com/problems/permutations/

难度:

Medium

Tag是backtracking,感觉最初来莫算法,最自不量力的时候接触到过backtracking,CS106B也有讲过backtracking,只记得讲的很好。

谷歌了一下,看一下backtracking的用法:

Gen­er­al­ized Algorithm:

Pick a starting point.
while(Problem is not solved)
    For each path from the starting point.
        check if selected path is safe, if yes select it
                and make recursive call to rest of the problem
        If recursive calls returns true, then return true.
        else undo the current move and return false.
    End For
    If none of the move works out, return false, NO SOLUTON.

这个题目一方面可以看成从[]开始加各种调料,但一般&常见的做法是看成原本的来swap.

两种解法都可以找到解答。

backtracking的本质还是递归

to do - backtrack依旧需要更详细的学习

class Solution(object):
    def permute(self, nums):
        """
        :type nums: List[int]
        :rtype: List[List[int]]
        """
        result = []
        self.helper(nums,0,result)
        return result
    
    def helper(self,nums,begin,result):
        n = len(nums)
        if begin == n:
            tmp = nums[:]
            result.append(tmp)
            return
        
        for i in range(begin,n):
            nums[begin], nums[i] = nums[i],nums[begin]
            self.helper(nums,begin+1,result)
            nums[begin],nums[i] = nums[i],nums[begin]
     
上一篇下一篇

猜你喜欢

热点阅读