LeetCode 46-50 记录

46

https://leetcode-cn.com/problems/permutations/

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
from typing import List


class Solution:
def permute(self, nums: List[int]) -> List[List[int]]:
def permutation(nums):
if len(nums) == 1:
yield nums[0:1]
else:
for perm in permutation(nums[1:]):
for i in range(len(perm) + 1):
yield perm[:i] + nums[0:1] + perm[i:]
return list(permutation(nums))


if __name__ == '__main__':
s = Solution()
print(s.permute([1, 2, 3]))

就是递归。想到了就是想到了。思路的话都好想,就是怎么转化成代码。


LeetCode 46-50 记录
http://fanlumaster.github.io/2022/03/05/LeetCode-46-50-记录/
作者
fanlumaster
发布于
2022年3月5日
许可协议