根据数字生成唯一数字_图解LeetCode:如何生成数字全排列

646a4f844afa9e4c03da2877ccf8d029.png

这是LeetCode的第46号题目Permutations,也就是排列的意思,给定一个数字集,比如[1,2,3],让我们返回这些数字全排列。

全排列的概念我们都很熟悉,高中数学时没少受排列组合问题的折磨。

给定[1,2,3],相比你能轻松的计算出其全排列是:

123,132,213,132,312,321

你可能觉得这也太简单了吧,简直一眼就能看出答案,但是,这里给定的数字集就三个,如果给你一个[1,2,3,4,5,6,7,8,9]这样的数字集答案还明显吗,你能一下说出[1,2,3,4,5,6,7,8,9]这九个数字的全排列是什么吗?

聪明的你肯定意识到了这不那么容易的事情,显然,9个数字的全排列组合个数是9!,也就是有362880个排列组合,我们人类的大脑天生不适合处理这种机械式的问题,因为这非常繁琐,但是,这一切对于计算机来说不是问题。

那么你该怎么告诉计算机求出一个数字集的全排列呢?

我的思路

很显然,你需要某种策略,这种策略能明确的告诉计算机——也就是利用算法,每一步该如何处理直到计算出所有的全排列,那么这种策略

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值