Codeforces Round #131 Div1 B
Problem
给出Ai(i∈[0,9])。表示每一个数字至少须要出现多少次。问有多少个数满足下面三个条件:1. 数至多有N位;2. 数不含有前导0;3. 每一个数 i 出现的次数不少于Ai(mod 1e9+7)
Limits
TimeLimit(ms):2000
MemoryLimit(MB):256
N∈[1,100]
Ai∈[0,100]
Look up Original Problem From here
Solution
实际上是一种填数、计数统计的问题。
考虑填0的情况。在此基础上。考虑填1的情况。…。最后考虑填9的情况。
因为不可含有前导0,最好还是先枚举如果第一个数字,而剩下的N-1位数字进行填数。设dp[i][j]表示当前填下的这个数为 i,数的长度是 j 时有多少个数满足题意。
转移方程:dp[now][i+j]=dp[now][i+j]+dp[now−1][j]×Cin−j。统计答案,ans=∑nj=0(dp[9][j]Cn−jn)。除法不满足取模运算。用逆元解决。
Complexity
TimeComplexity:O(9⋅9⋅N2)
MemoryComplexity:O(N2)
My Code
//Hello. I'm Peter.
#include<cstdio>
#include<iostream>
#include<sstream>
#include<cstring>
#include<string>
#include<cmath>
#include<cstdlib>
#include<algorithm>
#include<functional>
#include<cctype>
#include<ctime>
#include<stack>
#include<queue>
#include<vector>
#include<set>
#include<map>
using namespace std;
typedef long long ll;
typedef long double ld;
const double pi=acos(-1.0);
#define peter cout<<"i am peter"<<endl
#define randin srand((unsigned int)time(NULL))
#define INT (0x3f3f3f3f)*2
#define LL (0x3f3f3f3f3f3f3f3f)*2
#define input freopen("data.txt","r",stdin)
#define gsize(a) (int)a.size()
#define len(a) (int)strlen(a)
#define slen(s) (int)s.length()
#define clr(a) memset(a,0,sizeof(a))
#define clr_queue(q) while(!q.empty()) q.pop()
#define clr_stack(s) while(!s.empty()) s.pop()
#define rep(i, a, b) for (int i = a; i < b; i++)
#define dep(i, a, b) for (int i = a; i > b; i--)
#define repin(i, a, b) for (int i = a; i <= b; i++)
#define depin(i, a, b) for (int i = a; i >= b; i--)
#define esp 1e-6
#define MAXN
#define N 200
#define M
const ll mod=1e9+7;
ll C[N][N],ans,dp[15][N];
int n,a[N],sum;
void init_C(){
clr(C);
rep(i,0,N){
C[i][0]=1;
}
rep(i,1,N){
rep(j,1,N){
C[i][j]=(C[i-1][j-1]+C[i-1][j])%mod;
}
}
}
ll quick_power(ll x,ll y){
if(!y) return 1;
ll res=quick_power(x,y>>1);
res=res*res%mod;
if(y%2) res=res*x%mod;
return res;
}
int main(){
init_C();
ans=0;
scanf("%d",&n);
rep(i,0,10){
scanf("%d",a+i);
}
repin(de,1,9){
a[de]-=1;
n-=1;
repin(i,0,9){
repin(j,0,n){
dp[i][j]=0;
}
}
repin(i,0,n){
if(i>=a[0]) dp[0][i]=C[n][i];
}
repin(now,1,9){
repin(i,0,n){
if(i<a[now]) continue;
repin(j,0,n){
if(i+j>n || !dp[now-1][j]) continue;
dp[now][i+j]=(dp[now][i+j]+dp[now-1][j]*C[n-j][i])%mod;
}
}
}
repin(i,0,n){
// ans=(ans+dp[9][i]/C[n][n-i]); 不能直接求。转化为逆元来做。
ans=(ans+dp[9][i]*quick_power(C[n][n-i],mod-2))%mod;
}
n+=1;
a[de]+=1;
}
printf("%lld\n",ans);
}
Codeforces Round #131 Div1 B的更多相关文章
- Codeforces Round #543 Div1题解(并不全)
Codeforces Round #543 Div1题解 Codeforces A. Diana and Liana 给定一个长度为\(m\)的序列,你可以从中删去不超过\(m-n*k\)个元素,剩下 ...
- Codeforces Round #545 Div1 题解
Codeforces Round #545 Div1 题解 来写题解啦QwQ 本来想上红的,结果没做出D.... A. Skyscrapers CF1137A 题意 给定一个\(n*m\)的网格,每个 ...
- Codeforces Round #539 Div1 题解
Codeforces Round #539 Div1 题解 听说这场很适合上分QwQ 然而太晚了QaQ A. Sasha and a Bit of Relax 翻译 有一个长度为\(n\)的数组,问有 ...
- [Codeforces Round #254 div1] C.DZY Loves Colors 【线段树】
题目链接:CF Round #254 div1 C 题目分析 这道题目是要实现区间赋值的操作,同时还要根据区间中原先的值修改区间上的属性权值. 如果直接使用普通的线段树区间赋值的方法,当一个节点表示的 ...
- Codeforces Round #131 (Div. 1) B. Numbers dp
题目链接: http://codeforces.com/problemset/problem/213/B B. Numbers time limit per test 2 secondsmemory ...
- Codeforces Round #131 (Div. 2) B. Hometask dp
题目链接: http://codeforces.com/problemset/problem/214/B Hometask time limit per test:2 secondsmemory li ...
- Codeforces Round #131 (Div. 2) E. Relay Race dp
题目链接: http://codeforces.com/problemset/problem/214/E Relay Race time limit per test4 secondsmemory l ...
- Codeforces Round #253 DIV1 C 馋
http://codeforces.com/contest/442/problem/C 题意非常easy,基本上肯定有坑坑洼洼的样子.看题目案例,从第三个跟第二个没有凹的案例来看的话,多写几个以及多画 ...
- Codeforces Round #413 (Div1 + Div. 2) C. Fountains(树状数组维护最大值)
题目链接:https://codeforces.com/problemset/problem/799/C 题意:有 c 块硬币和 d 块钻石,每种喷泉消耗硬币或钻石中的一种,每个喷泉有一个美丽值,问建 ...
随机推荐
- ***解决UEditor编辑器无法插入第三方视频地址
转:http://blog.csdn.net/qq_16241043/article/details/53894847 xssFilter导致插入视频异常,编辑器在切换源码的过程中过滤掉img的_ur ...
- Android Studio从2.3升级到3.1注意事项
原文:https://blog.csdn.net/lithiumyoung/article/details/80111111 Android Studio从2.3升级到3.1注意事项 项目根目录下的b ...
- 图学ES6-3.变量的解构赋值
- React、Redux 和 Bootstrap
使用 React.Redux 和 Bootstrap 实现 Alert 今天,我们来学习使用 React.Redux 和 Bootstrap 实现Alert. 例子 这个例子实现了弹出不同类型信息的功 ...
- 009 jquery过滤选择器-----------(表单对象属性过滤选择器 与 表单选择器)
1.表单对象属性选择器 2.程序 <!DOCTYPE html> <html> <head> <meta charset="UTF-8"& ...
- php 会话控制(Session会话控制)
php的session会话是通过唯一的会话ID来驱动的,会话ID是一个加密的随机数字,由php生成,在会话的生命周期中都会保存在客户端.客户端保存数据的地方只有cookie,所以php的会话ID一般保 ...
- 2015 ACM Amman Collegiate Programming Contest 题解
[题目链接] A - Who Is The Winner 模拟. #include <bits/stdc++.h> using namespace std; int T; int n; s ...
- 001.Parted工具使用
一 Parted简介 1.1 parted和fdisk 通常使用较多的磁盘管理工具为fdisk,但由于磁盘越来越廉价,且磁盘空间越来越大,而fdisk工具分区存在大小限制,只能划分小于2T的磁盘.因此 ...
- linux环境下source vimrc提示错误unexpected token `"autocmd"'
编辑完vimrc之后,使用source /etc/vimrc之后报错: $ source /etc/vimrc bash: /etc/vimrc: line 15: syntax error near ...
- JFreeChart 之饼图
JFreeChart 之饼图 一.JFreeChart 简介 JFreeChart是JAVA平台上的一个开放的图表绘制类库.它完全使用JAVA语言编写,是为applications, applets, ...