MATLAB_排列组合_组合生成程序

   已知有m个箱子,箱子里分别有n_1,n_2,...,n_m个球,所有球都不同。从每个箱子里都取出一个球,生成出所有的组合。

%% 函数定义
% 设有m个盒子,每个盒子里各有n1,n2,...,nm个不同的球。
% 从每个盒子中各取一个球,共有几种组合,列出所有组合。
function COM = Combination_MN(num_ball)
%% 参数设置
% num_ball 每个盒子中球的个数,[n1,n2,...,nm];
num_box = length(num_ball); % 盒子个数
%% 函数体
NumCom = 1; % 共有多少种组合
for i_box = 1:num_box
    NumCom = NumCom*num_ball(i_box);
end
COM = zeros(NumCom,num_box); % 初始化组合向量
i_com = 1; % 当前组合在COM中的地址
com = ones(1,num_box); % 当前组合
COM(i_com,:) = com; % 所有组合
while ~isequal(com,num_ball)
    com(end) = com(end) + 1;
    for i_box = num_box:-1:2
        if com(i_box)>num_ball(i_box)
            com(i_box) = 1; com(i_box-1) = com(i_box-1) + 1;
        end
    end
    i_com = i_com + 1;
    COM(i_com,:) = com;
end

 

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值