题解 | #字符串的排列#
字符串的排列
https://www.nowcoder.com/practice/fe6b651b66ae47d7acce78ffdd9a96c7
#
# 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
#
#
# @param str string字符串
# @return string字符串一维数组
#
class Solution:
def Permutation(self , str: str) -> List[str]:
# write code here
ans = []
path = [''] * len(str)
onPath = [False] * len(str)
str = list(str)
str.sort()
def dfs(i: int) -> None:
if i == len(str):
ans.append(path.copy())
return
for j in range(0, len(str)):
if onPath[j] or (j > 0 and str[j] == str[j - 1] and not onPath[j - 1]):
continue
path.append(str[j])
onPath[j] = True
dfs(i + 1)
path.pop()
onPath[j] = False
dfs(0)
return [''.join(item) for item in ans]

