32.1 leetcode - 没有重复数据的全排列

本文介绍了一个使用Python实现的全排列算法。通过递归的方式,该算法可以找出给定不重复整数集合的所有可能排列组合。文章包含完整的源代码示例,并详细解释了递归调用的过程。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

#!/usr/bin/python
# -*- coding: utf-8 -*-
'''
Permutations
Given a collection of distinct numbers, return all possible permutations.(没有重复数字的全排列)
[
  [1,2,3],
  [1,3,2],
  [2,1,3],
  [2,3,1],
  [3,1,2],
  [3,2,1]
]
'''
class Solution(object):
    def permute(self, nums):
        """
        :type nums: List[int]
        :rtype: List[List[int]]
        """
        length = len(nums)
        if length == 0:
            return []
        ret = []
        self.__permute(nums,0,length,ret)
        return ret

    def __permute(self,nums,start,length,ret):
        if start == length - 1:
            ret.append(list(nums))  #如果不加list结果是错的,因为引用
            return
        #两两交换
        for index in range(start,length):
            tmp = nums[start]
            nums[start],nums[index] = nums[index],tmp
            self.__permute(nums,start + 1,length,ret)
            tmp = nums[start]
            nums[start],nums[index] = nums[index],tmp

if __name__ == "__main__":
    s = Solution()
    print s.permute([1,2,3])
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值