Codeforces 451E Devu and Flowers(组合计数)
在WFU(不是大学简称)第二次比赛中做到了这道题。高中阶段参加过数竞的同学手算这样的题简直不能更轻松,只是套一个容斥原理公式就可以。而其实这个过程放到编程语言中来实现也没有那么的复杂,不过为了让计算机在限定的时间内完成计算需要进行一些对计算上的优化。模MOD的情况下计算组合数nCr只需要求出分子再乘以分母的逆元,考虑到模的是1e9+7本身就是一个质数,根据费马小定理a^(MOD-2)即是a在模MOD意义下的逆元。求逆元的时候为了节约计算时间可以采用快速幂。计算过程就是容斥原理,就没有什么好说的了。
参考代码
#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
const int MOD=(int)1e9+;
ll f[],fact[];
ll fast_exp(ll base,ll exp,ll mod)
{
ll res=;
while(exp)
{
if(exp&)
res=res*base%mod;
base=base*base%mod;
exp>>=;
}
return res;
}
ll inverse_mod(ll x,ll mod)
{
return fast_exp(x,mod-,mod);
}
ll nCr(ll n,ll r)
{
if(n<r)
return ;
r=min(r,n-r);
ll ret=;
for(ll x=n;x>n-r;x--)
{
ret=(ret*(x%MOD))%MOD;
}
ret=(ret*inverse_mod(fact[r],MOD))%MOD;
return ret;
}
int main()
{
ios_base::sync_with_stdio(false);
cin.tie(NULL);
int n,i,j,N,cnt;
ll s,temp,ans=;
fact[]=;
for(i=;i<;i++)
fact[i]=(fact[i-]*i)%MOD;
cin>>n>>s;
for(i=;i<n;i++)
cin>>f[i];
N=<<n;
for(i=;i<N;i++)
{
temp=,cnt=;
for(j=;j<n;j++)
{
if(i&(<<j))
{
temp+=(f[j]+);cnt++;
}
}
if(temp>s)
continue;
ll x=nCr(s-temp+n-,n-);
if(cnt%!=)
x*=(-);
ans=(ans+x+MOD)%MOD;
}
cout<<ans<<"\n";
return ;
}
果然计算机和数学联系还是十分密切,当初搞数竞的时候觉得那些奇技淫巧恐怕难觅用武之地,结果现在才发现这些原来在编程中有很大的应用……眼前又是新的挑战,无论如何都不想再经历像高三那一年一样的绝望了吧……那么,加油吧,就像曾经一样,付出你的全部热情。不论你还相不相信你还可以成功,这都是可能使你回到巅峰的唯一途径了。让苦难成为力量。
Codeforces 451E Devu and Flowers(组合计数)的更多相关文章
- Codeforces 451E Devu and Flowers(容斥原理)
题目链接:Codeforces 451E Devu and Flowers 题目大意:有n个花坛.要选s支花,每一个花坛有f[i]支花.同一个花坛的花颜色同样,不同花坛的花颜色不同,问说能够有多少种组 ...
- Codeforces 451E Devu and Flowers【容斥原理+卢卡斯定理】
题意:每个箱子里有\( f[i] \)种颜色相同的花,现在要取出\( s \)朵花,问一共有多少种颜色组合 首先枚举\( 2^n \)种不满足条件的情况,对于一个不被满足的盒子,我们至少拿出\( f[ ...
- codeforces 451E Devu and Flowers
题意:有n个瓶子每个瓶子有 f[i] 支相同的颜色的花(不同瓶子颜色不同,相同瓶子花视为相同) 问要取出s支花有多少种不同方案. 思路: 如果每个瓶子的花有无穷多.那么这个问题可以转化为 s支花分到 ...
- codeforces 451E. Devu and Flowers 容斥原理+lucas
题目链接 给n个盒子, 每个盒子里面有f[i]个小球, 然后一共可以取sum个小球.问有多少种取法, 同一个盒子里的小球相同, 不同盒子的不同. 首先我们知道, n个盒子放sum个小球的方式一共有C( ...
- CodeForces - 451E Devu and Flowers (容斥+卢卡斯)
题意:有N个盒子,每个盒子里有fi 朵花,求从这N个盒子中取s朵花的方案数.两种方法不同当且仅当两种方案里至少有一个盒子取出的花的数目不同. 分析:对 有k个盒子取出的数目超过了其中的花朵数,那么此时 ...
- Codeforces 932E Team work 【组合计数+斯特林数】
Codeforces 932E Team work You have a team of N people. For a particular task, you can pick any non-e ...
- CF 451E Devu and Flowers
可重集的排列数 + 容斥原理 对于 \(\{A_1 * C_1, A _2 * C_2, \cdots, A_n * C_n\}\)这样的集合来说, 设 \(N = \sum_{i = 1} ^ n ...
- codeforces 691F F. Couple Cover(组合计数)
题目链接: F. Couple Cover time limit per test 3 seconds memory limit per test 512 megabytes input standa ...
- Codeforces Round #258 (Div. 2) E. Devu and Flowers 容斥
E. Devu and Flowers 题目连接: http://codeforces.com/contest/451/problem/E Description Devu wants to deco ...
随机推荐
- jQuery的deferred对象详解(转载)
本文转载自: jQuery的deferred对象详解(转载)
- HTML5 UI框架Kendo UI Web中如何创建自定义组件(二)
在前面的文章<HTML5 UI框架Kendo UI Web自定义组件(一)>中,对在Kendo UI Web中如何创建自定义组件作出了一些基础讲解,下面将继续前面的内容. 使用一个数据源 ...
- Stockbroker Grapevine(floyd+暴力枚举)
Stockbroker Grapevine Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 31264 Accepted: 171 ...
- draggable datagrid columns
$.extend($.fn.datagrid.methods,{ columnMoving: function(jq){ return jq.each(function(){ var target = ...
- 【前端】互联网公司2014前端笔试面试题JavaScript篇(待续)
// 网上找的题目,自己做了下 /**************************** *1. 用js实现随机选取10–100之间的10个数字,存入一个数组,并排序 *************** ...
- javascript 面向对象(转)
1.使用[]调用对象的属性和方法 function User() { this.age = 21; this.sex = "男?"; } var user = new User() ...
- CentOS7网卡的命名规则
一.前两个字符的含义 en 以太网 Ethernet wl 无线局域网 WLAN ww 无线广域网 WWAN 二.第三个字符的含义 o on-board device index number s h ...
- Java开发中经典的小实例-(100能被3整除的数打印出来)
public class Test21 { public static void main(String[] args) { // TODO Auto-generated meth ...
- hdu 4358 Boring counting dfs序+莫队+离散化
Boring counting Time Limit: 6000/3000 MS (Java/Others) Memory Limit: 98304/98304 K (Java/Others) ...
- svn ubuntu command(转载)
转载来自:http://blog.csdn.net/pkueecser/article/details/6830758 将文件checkout到本地目录 svn checkout path(path ...