LightOJ - 1067 - 組み合わせ(組み合わせ数)

リンク:

https://vjudge.net/problem/LightOJ-1067

質問の意味:

与えられたn個の異なるオブジェクトが、あなたはそれらのk個を取りたいです。どのように多くの方法それを行うことができますか?

例えば、4つの項目があると言います。あなたはそれらの2を取りたいです。だから、あなたはそれを6つの方法を行うことができます。

、1テイク2

、1〜3を取ります

、1テイク4

、テイク2 3

、2テイク4

、3を取る4

アイデア:

組み合わせの数。

コード:

#include<iostream>
#include<cstdio>
#include<cstring>
#include<string>
#include<algorithm>
#include<math.h>
#include<vector>
#include<map>
#include<set>
#include<utility>

using namespace std;
typedef long long LL;
const int INF = 1e9;

const int MAXN = 1e6+10;
const int MOD = 1e6+3;

int n, k;
int P[MAXN];

LL PowMod(int a, int b)
{
    LL res = 1;
    while(b)
    {
        if (b&1)
            res = (1LL*res*a)%MOD;
        a = (1LL*a*a)%MOD;
        b >>= 1;
    }
    return res;
}

void Init()
{
    P[1] = 1;
    for (int i = 2;i < MAXN;i++)
        P[i] = 1LL*i*P[i-1]%MOD;
}

int main()
{
    Init();
    int cnt = 0;
    int t;
    scanf("%d", &t);
    while(t--)
    {
        printf("Case %d:", ++cnt);
        scanf("%d%d", &n, &k);
        if (k == 0 || n == k)
        {
            puts(" 1");
            continue;
        }
        int tmp = 1LL*P[k]*P[n-k]%MOD;
        tmp = PowMod(tmp, MOD-2);
        printf(" %lld\n", 1LL*P[n]*tmp%MOD);
    }
    
    return 0;
}

おすすめ

転載: www.cnblogs.com/YDDDD/p/11886520.html