剑指offer python版 字符串的排列

from itertools import permutations


def my_permutation(s):
    str_set = []
    ret = []  # 最后的结果

    def permutation(string):
        for i in string:
            str_tem = string.replace(i, '')
            str_set.append(i)
            if len(str_tem) > 0:
                permutation(str_tem)
            else:
                ret.append(''.join(str_set))
            str_set.pop()

    permutation(s)
    return ret


if __name__ == '__main__':
    s = 'abc'
    print my_permutation(s)
print [''.join(p) for p in permutations(s)

 

posted @ 2018-10-26 11:17  findtruth123  阅读(444)  评论(0编辑  收藏  举报