输入一个字符串,打印出该字符串中字符的所有排列。
你可以以任意顺序返回这个字符串数组,但里面不能有重复元素。
示例:
输入:s = "abc"
输出:["abc","acb","bac","bca","cab","cba"]
限制:
1 <= s 的长度 <= 8
关于深度优先遍历的考察,这个题目很典型。虽然刚开始已经把递归树画出来了,但是在写代码时候还是没有写出来。关键是理解:字符串的全排列,要确定好每个位置上的字符。对于重复的结果使用set进行去重。
方法一:未进行记忆优化
如何确定好每个位置上的字符,循环加递归:
class Solution(object):
def permutation(self, s):
"""
:type s: str
:rtype: List[str]
"""
ans = set()
vis = [False]*len(s)
def dfs(s,cur,curs,ans):
if cur==len(s):
ans.add(curs)
return
for i in range(len(s)):
if not vis[i]:
vis[i]=True
dfs(s,cur+1,curs+s[i],ans)
vis[i]=False
dfs(s,0,'',ans)
res =[val for val in ans]
return res
方法二:优化