UVA11609 - Teams(组合数学+快速幂)

来源:互联网 发布:fireworks mac版 编辑:程序博客网 时间:2024/06/06 03:22

题目链接


题意:从N个人中选出K个人为一只队伍(1 <= K <= N),每个队伍都要有一个队长,当队长不同时,所代表的队伍也不同,求一共可以选出多少只队伍。

思路:依题目可得ans = sum(i * C(i, n)),化简可得ans = n * sum(C(i, n - 1)) = n * 2 ^ (n - 1)。之后用快速幂求解。

代码:

#include <iostream>#include <cstdio>#include <cstring>#include <cmath>#include <algorithm>typedef long long ll;const int MOD = 1000000007;using namespace std;ll n;/*ll pow_mod(ll k) {    if (k == 0)        return 1;    if (k == 1)        return 2;    ll a = pow_mod(k / 2);    ll ans = a * a % MOD;    if (k % 2)        ans = ans * 2 % MOD;    return ans;}*/ll pow_mod(ll k) {    ll ans = 1;    ll temp = 2;     while (k) {        if (k & 1)               ans = ans * temp % MOD;                k >>= 1;         temp = (temp * temp) % MOD;    }    return ans;}int main() {    int cas, t = 1;    scanf("%d", &cas);    while (cas--) {        scanf("%lld", &n);           ll ans = pow_mod(n - 1);                  ans = ans * n % MOD;         printf("Case #%d: %lld\n", t++, ans);    }    return 0;}


1 0
原创粉丝点击