求组合数:求n个数(1...n)中k个数的组合

博客介绍了如何通过递归算法计算从1到n的数字中选取k个数的所有可能组合。例如,combination(5, 3)将输出组合543, 542, 541, 532, 531, 521, 432, 431, 421, 321。算法核心是当k等于1时直接输出,否则对于每个选定的第一个数,递归处理剩余的数来选择k-1个数。" 108840289,6285691,使用Plex移动设备共享媒体:从一台设备到另一台设备,"['流媒体', '移动开发', 'Plex', 'iOS', 'Android']
摘要由CSDN通过智能技术生成

如:combination(5,3)

要求输出:543,542,541,532,531,521,432,431,421,321

递归,当k等于1的时候进行输出,

当第一个数选的5,则从剩下的4321中选2个数,即combination(4,2)

    第二个数选的4,则从剩下的321中选1个数,即combination(3,1),输出543,542,541

    第二个数选的3,则从剩下的21中选1个数,即combination(2,1),输出532,531

    第二个数选的2,则从剩下的1中选1个数,即combination(1,1),输出521

当第一个数选的4,则从剩下的321中选2个数,即combination(3,2)

    第二个数选的3,则从剩下的21中选1个数,即combination(2,1),输出432,431

    第二个数选的2,则从剩下的1中选1个数,即combination(1,1),输出421

当第一个数选的3,则从剩下的21中选2个数,即combination(2,2)

    第二个数选的2,则从剩下的1中选1个数,即combination(1,1),输出321

import java.util.ArrayList;

publ
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值