常用数学公式的编程表达

今天把常用数学公式用C/C++表达组织一下,以便日后使用。

排列组合数


先来看看排列组合数的公式:

Amn=n(n1)(nm+1)=n!(nm)!

Cmn=Amnm!=n!m!(nm)!=Cnmn


显然写程序的话, Amn 很容易用一个for循环表示,而 Cmn=n(n1)(nm+1)1×2m 的形式更容易用for循环表示,直接看代码:

// 排列组合数
#define  uint   unsigned int

// 函数名称: Anm
// 函数功能: 从n中取m的全排列数
uint  Anm(uint n, uint m)
{
    uint sum = 1, i = 1;

    for(i=n; i>= (n-m+1); i--)
        sum *= i;

    return (sum);   
}

// 函数名称: Cnm
// 函数功能: 从n中取m的组合数
uint  Cnm(uint n, uint m)
{
    uint i = 1, sum = 1;

    for(i=1; i<=m; i++)
        sum = sum * (n+1-i)/i;    // 千万不可错写成了 sum *= (n+1-i)/i;

    /*
    * 千万不可错写成了 sum *= (n+1-i)/i;
    * 因为后者会先计算分式,会导致整数互质除不尽的错误
    */ 

    return (sum);
}

随机输出任意一个全排列

// 函数名称: RandArrange
// 函数功能: 在指定范围内输入任意的一个全排列
#include  <algorithm>
#include  <time.h>
#define   uint    unsigned int
void   RandArrange(uint* uiResTbl, uint rangeMin, rangeMax)
{
    // Seed the random-number generator with the current time so that
    // the numbers will be different every time we run.
    srand((uint)time(NULL));

    uint  nCnt = rangeMax - rangeMin + 1;
    uint  uiRand, i, j;

    i = j = 0;
    memset(uiResTbl, -1, nCnt);
    while(i < nCnt)
    {
        j = 0;
        uiRand = (double)rand() / (RAND_MAX + 1) *  (rangeMax + 1 - rangeMin) + rangeMin;
        while(j < i)
        {
            if(uiResTbl[j] == uiRand)   break;
            j++;
        }
        if(i != j)
            continue;

        uiResTbl[i] = uiRand;

        i++;
    }   
}

十分值得注意的是,此函数并不稳定,产生满足要求的全排列的时间不定。
随机输出一组全排列的情况在实际的仿真中用得比较多,如从某数据集中随机选取指定数目的样本。(显然这是一种简单的求部分全排列)而MATLAB中有现成的输出随机全排列的函数 randperm
在MATLAB命令窗口中Help randperm函数:
这里写图片描述
与上面这个 RandArrange函数不同的是,MATLAB中的randperm函数是输出从1到n的一组随机全排列,不能指定下限。

  • 3
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 4
    评论
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

轻蓝雨

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值