组合数汇总

DP:

C++ 计算组合数(动态规划)
递归:
求组合数 C++程序
C++组合数(combination)的实现

//  计算组合数:使用动态规划算法
 
#include <iostream>
 
int mat[100][100];
 
int combinat(int m, int n) {
    int i, j;
    
    if(n == 0 || m == n)
        return 1;
// // 一行一行的计算下去
//    for(i = 1; i <= m; i++) { // m一般不能为0
//        for(j = 0; j <= i && j <= n; j++) { // 当i大于n的时候不用计算,即不用计算n列候的数,节省时间
//            if(j == 0 || j == i)
//                mat[i][j] = 1;
//            else
//                mat[i][j] = mat[i-1][j-1] + mat[i-1][j];
//        }
//    }
    // 一列一列的计算下去
    for(j = 0; j <= n; j++) { // 只要计算n列就行了,不用计算后面的
        mat[j][j] = 1;
        for(i = j+1; i <= m; i++) {
            if(j == 0)
                mat[i][j] = 1;
            else
                mat[i][j] = mat[i-1][j-1] + mat[i-1][j];
        } // 计算Cmn
    }
    return mat[m][n];
}
 
int main(int argc, const char * argv[]) {
    // insert code here...
    int m, n;
    
    std::cout << "请输入组合数的m和n:";
    std::cin >> m >> n;
    std::cout << combinat(m, n) << std::endl;
    return 0;
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值