输入一个字符串,按字典序打印出该字符串中字符的所有排列。例如输入字符串abc,则打印出由字符a,b,c所能排列出来的所有字符串abc,acb,bac,bca,cab和cba。
思路:
递归思路。
循环固定第一个位置字母,则后面的排序数等于其余字符的排序。对其余字符也一样进行这样的操作。
最后使用set去重,并排序。
代码:
# -*- coding:utf-8 -*-
class Solution:
def Permutation(self, ss):
# write code here
if ss==[]:
return []
if len(ss)==1:
return ss
res=[]
for i in range(len(ss)):
for j in self.Permutation(ss[:i]+ss[i+1:]):
res.append(ss[i]+j)
return sorted(list(set(res)))