传送门

神仙计数!

我的计数真的好差啊= =

不过这个题真的神仙

看了题解把整个过程在草稿纸上重写了一遍才想明白= =(一张草稿纸就没有了!!!)

计数的关键就是在于 枚举的有效性和独立性【不能重复计数】

然后我们就来思考一下这个题

1. 确定t

我们重定义t为第一个取出的蓝球的位置

那么t的选择区间是[1,a+1] 分别对应[a+1,1]的时候取出

枚举区间:[1,a+1]

2.枚举i

取走前面的 a+1-t个 红球 和 在位置t的 1个 蓝球(根据第一步的定义)

这个时候总共取出了 a-t+2个 球 还没有取的有 b-1个 蓝球 和 t-1个 红球

我们发现现在红球和蓝球可以任意排列 因为t所在的位置开始全部都是蓝球 而1开始全部都是红球

这样计数不会重复因为最开始枚举的t保证了前面取出的已经不同

此时我们枚举i表示取走的蓝球数量

我们的可以任取几个球呢? 答案是 b-1个 因为t所在的位置在球数<t的时候就失效了 所以 b+t-2-(t-1)=b-1

所以i的枚举区间是[0,b-1]

这时候的贡献 : C(i,b-1)

考虑现在剩下的球的个数 有 t-1-i个 红球 和 i个蓝球

3.确定s

这时候我们的t已经失效了 并且已知了前面的互不相同的序列

s的枚举范围与t类似 这个时候s表示现在开始第一个取蓝球的位置

和第一步同理 表示先取 t-i-s个 红球再取 1个 蓝球

枚举区间:[1,t-i]

4.枚举j

考虑此时剩下了 s-1个 红球 和 i-1个 蓝球

此时位置s开始全是蓝球 1位置全是红球 又可以任选啦=v=

我们考虑枚举j表示 取出 j个 红球 和 i-1-j个 蓝球

这个的贡献就是:C(j,i-1)

枚举区间对应的是[0,min(s-1,i-1)]

于是我们现在按照这个做得到了一个的枚举大法

接着考虑优化 首先j一定是可以对应一个前缀和的当然就是f[i-1][s-1]

s的枚举也是可以用前缀和优化掉的 就是对f进行前缀和得到sum[i-1][t-i-1](注意细节i可以取到0所以要每次枚举t的时候++)

然后这样的话我们就得到了一个非常优秀的做法

这样就是可以通过的啦=v=

完结撒花~

#include<cstdio>
#include<cstring>
#include<algorithm>
#include<cmath>
#define inf 20021225
#define ll long long
#define N 2000
#define mdn 1000000007
using namespace std; int f[N+10][N+10],sum[N+10][N+10],C[N+10][N+10]; void prework()
{
C[0][0]=C[1][0]=C[1][1]=1;
//f[0][0]=sum[0][0]=1;
for(int i=2;i<=N+1;i++)
{
C[i][0]=C[i][i]=1;
for(int j=1;j<i;j++) C[i][j]=(C[i-1][j-1]+C[i-1][j])%mdn;
}
for(int i=0;i<=N+1;i++)
{
f[i][0] = C[i][0];
for(int j=1;j<=N+1;j++)
f[i][j] = (f[i][j-1] + C[i][j])%mdn;
}
for(int i=0;i<=N+1;i++)
{
sum[i][0] = f[i][0];
for(int j=1;j<=N+1;j++)
sum[i][j]=(sum[i][j-1] + f[i][j])%mdn;
}
}
int a,b;
void work()
{
int ans=0;
prework();
for(int t=1;t<=a+1;t++)
{
ans++;
for(int i=1;i<=min(t-1,b-1);i++)
{
ans += (ll)C[b-1][i]*sum[i-1][t-i-1]%mdn;
ans %= mdn;
}
}
printf("%d\n",ans);
} int main()
{
scanf("%d%d",&a,&b);
work();
return 0;
}

Code Festival 2017 Qual B E Popping Balls的更多相关文章

  1. Atcoder CODE FESTIVAL 2017 qual B E - Popping Balls 组合计数

    题目链接 题意 \(A+B\)个球排成一行,左边\(A\)个为红球,右边\(B\)个为蓝球. 最开始可以选择两个数\(s,t\),每次操作可以取左起第\(1\)或\(s\)或\(t\)个球.问有多少种 ...

  2. CODE FESTIVAL 2017 qual B B - Problem Set【水题,stl map】

    CODE FESTIVAL 2017 qual B B - Problem Set 确实水题,但当时没想到map,用sort后逐个比较解决的,感觉麻烦些,虽然效率高很多.map确实好写点. 用map: ...

  3. CODE FESTIVAL 2017 qual B C - 3 Steps【二分图】

    CODE FESTIVAL 2017 qual B C - 3 Steps 题意:给定一个n个结点m条边的无向图,若两点间走三步可以到,那么两点间可以直接连一条边,已经有边的不能连,问一共最多能连多少 ...

  4. 【AtCoder】CODE FESTIVAL 2017 qual B

    最近不知道为啥被安利了饥荒,但是不能再玩物丧志了,不能颓了 饥荒真好玩 A - XXFESTIVAL CCFESTIVAL #include <bits/stdc++.h> #define ...

  5. CODE FESTIVAL 2017 qual B 题解

    失踪人口回归.撒花\^o^/ 说来真是惭愧,NOI之后就没怎么刷过题,就写了几道集训队作业题,打了几场比赛还烂的不行,atcoder至今是蓝名=.= 以后还是多更一些博客吧,我可不想清华集训的时候就退 ...

  6. 【题解】Popping Balls AtCoder Code Festival 2017 qual B E 组合计数

    蒟蒻__stdcall终于更新博客辣~ 一下午+一晚上=一道计数题QAQ 为什么计数题都这么玄学啊QAQ Prelude 题目链接:这里是传送门= ̄ω ̄= 下面我将分几个步骤讲一下这个题的做法,大家不 ...

  7. CODE FESTIVAL 2017 qual B

    昨晚因为有点事就去忙了,没打后悔啊 A - XXFESTIVAL Time limit : 2sec / Memory limit : 256MB Score : 100 points Problem ...

  8. Atcoder CODE FESTIVAL 2017 qual C D - Yet Another Palindrome Partitioning 回文串划分

    题目链接 题意 给定一个字符串(长度\(\leq 2e5\)),将其划分成尽量少的段,使得每段内重新排列后可以成为一个回文串. 题解 分析 每段内重新排列后是一个回文串\(\rightarrow\)该 ...

  9. Atcoder CODE FESTIVAL 2017 qual C C - Inserting 'x' 回文串

    题目链接 题意 给定字符串\(s\),可以在其中任意位置插入字符\(x\). 问能否得到一个回文串,若能,需插入多少个\(x\). 思路 首先统计出现次数为奇数的字符\(cnt\). \(cnt\ge ...

随机推荐

  1. vue双向数据绑定对于数组和新增对象属性不能监听的解决办法

    出现数组不能按照索引进行跟新的原因是处于性能考虑的,但是整体数组的增加删除是可以监听到的:对于对象新增属性不能监听是因为没有在生成vue实例时候放进watcher收集依赖. 首先我们先来了解vue数据 ...

  2. Solr核心(内核)

    Solr核心(内核)   Solr核心(Core)是Lucene索引的运行实例,包含使用它所需的所有Solr配置文件.我们需要创建一个Solr Core来执行索引和分析等操作. Solr应用程序可以包 ...

  3. 洛谷P1441 砝码称重(搜索,dfs+bitset优化)

    洛谷P1441 砝码称重 \(n\) 的范围为 \(n \le 20\) ,\(m\) 的范围为 \(m \le 4\) . 暴力遍历每一种砝码去除情况,共有 \(n^m\) 种情况. 对于剩余砝码求 ...

  4. CDN-template

    ylbtech-CDN: 1.返回顶部   2.返回顶部   3.返回顶部   4.返回顶部   5.返回顶部     6.返回顶部   7.返回顶部   8.返回顶部   9.返回顶部   10.返 ...

  5. 测开之路八十三:高级函数:map()和filter()

    # map(函数名,可迭代对象)# 给可迭代对象的每个值+5l = list(range(1, 21)) def add_number(x):    return x + 5 # 第一种方式print ...

  6. virtualenv-windows下排坑

    1. 安装 pip install virtualenv pip install virtualenvwrapper-win    (win下一定要有这个 -win,不然后续 workon,mkvir ...

  7. Docker安装Web前端性能测试工具Sitespeed.io

    一.Sitespeed.io概述 1.Sitespeed.io简介 Sitespeed.io:是一款开源的Web性能测试工具,用来衡量Web网站的综合性能,帮助开发和测试人员分析网页的加载速度和渲染性 ...

  8. MQ基础知识学习

    之前听人提起了MQ协议,我就去稍微了解了一下什么是MQ,和MQ的一些基础性的知识. 什么是MQ呢? 消息队列(MQ)是一种应用程序对应用程序的通信方法.应用程序通过写和检索出入列队的针对应用程序的数据 ...

  9. msyql join语句执行原理

    首先,我建了一个表t2,里面有1000条数据,有id,a,b三个字段,a字段加了索引 然后我又建立一个t1表,里面有100条数据,和t2表的前一百条数据一致,也是只有id,a,b三个字段,a字段加了索 ...

  10. python time 和日期相关模块

    时间日期相关的模块 calendar 日历模块 time 时间模块 datetime 日期时间模块 timeit 时间检测模块 日历模块 calendar() 功能:获取指定年份的日历字符串 格式:c ...