Codewars第十天–Permutations

41 篇文章 1 订阅

Codewars第十天–Permutations

题目描述:
这是一道常见的全排列题目。需要返回输入字符串的所有排列并删除重复项(如果存在)。
例如:

permutations('a'); # ['a']
permutations('ab'); # ['ab', 'ba']
permutations('aabb'); # ['aabb', 'abab', 'abba', 'baab', 'baba', 'bbaa']

代码如下,使用递归来进行全排列操作,每一次将一个原字符串中的一个字符当做新的字符串的第一位,后面的子字符串同样以递归的方式进行遍历:

def permutations(string):
    if len(string) <= 1:
        return string
    else:
        result = []
        for i in range(len(string)):
            for j in permutations(string[0:i] + string[i+1:]):
                result.append(string[i] + j)
        return set(result)

如果不是为了学习,而是实际中需要全排列,可以直接使用itertools 模块中的permutationsiterable 为需要处理的字符串,r 为结果输出的字符串长度。

itertools.permutations(iterable, r)

代码可以改为:

import itertools

def permutations(string):
    return list("".join(str) for str in set(itertools.permutations(string)))
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值