剑指Offer.面试题38.字符串的排列

输入一个字符串,按字典序打印出该字符串中字符的所有排列。例如输入字符串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)))

你可能感兴趣的:(剑指Offer)