题解 | #字符串的排列#

字符串的排列

https://www.nowcoder.com/practice/fe6b651b66ae47d7acce78ffdd9a96c7

#
# 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
#
# 
# @param str string字符串 
# @return string字符串一维数组
#
class Solution:
        
    def Permutation(self , str: str) -> List[str]:
        # write code here
        sset = []
        rst = []

        if len(str) <= 1:
            return [str]
        for i in range(len(str)):
            s = str[i]
            if s in sset:
                continue
            sset.append(s)
            if i == len(str)-1:
                p = self.Permutation(str[:i])
            else:
                p = self.Permutation(str[:i]+str[i+1:])
            # print(p)
            for j in range(len(p)):
                p[j] = s + p[j]   
            rst += p
        return rst

方法:递归。

需要去除重复的排列。

全部评论

相关推荐

酷酷的喜马拉雅山:感觉这比一直在初筛不动的好多了
点赞 评论 收藏
分享
09-29 15:34
已编辑
北京航空航天大学 C++
做个有文化的流氓:结果是好的,过程不重要,而且你的offer太多了
软开人,秋招你打算投哪些...
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务