# 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
#
# 
# @param str string字符串 
# @return string字符串一维数组
#
class Solution:
    def Permutation(self , str: str) -> List[str]:
        # write code here
        c=list(str)
        res=[]
        def dfs(index):
            if index+1==len(str):
                res.append(''.join(c))
                return
            s=set()
            for i in range(index,len(str)):
                if c[i] in s:
                    continue
                s.add(c[i])
                c[i],c[index]=c[index],c[i]
                dfs(index+1)
                c[i],c[index]=c[index],c[i]
        dfs(0)
        return res