码迷,mamicode.com
首页 > 其他好文 > 详细

剑指offer 面试38题

时间:2018-06-24 21:02:59      阅读:173      评论:0      收藏:0      [点我收藏+]

标签:write   perm   abc   solution   char   第一个   IV   排列   code   

面试38题:

题:字符串的排列

题目:输入一个字符串,按字典序打印出该字符串中字符的所有排列。例如输入字符串abc,则打印出由字符a,b,c所能排列出来的所有字符串abc,acb,bac,bca,cab和cba。

解题思路:把字符串看成两部分:第一部分是它的第一个字符;第二部分是后面的所有字符。 递归

解题代码:

# -*- coding:utf-8 -*-
class Solution:
    def Permutation(self, ss):
        # write code here
        if not ss:
            return []
        if len(ss)==1:
            return list(ss)
        pStr=[]
        charlist=list(ss)
        charlist.sort()
        
        for i in range(len(charlist)):
            if i>0 and charlist[i]==charlist[i-1]:
                continue
            temp=self.Permutation(‘‘.join(charlist[:i])+‘‘.join(charlist[i+1:]))
            for j in temp:
                pStr.append(charlist[i]+j)
        return pStr

 

剑指offer 面试38题

标签:write   perm   abc   solution   char   第一个   IV   排列   code   

原文地址:https://www.cnblogs.com/yanmk/p/9221496.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!