D. Flowers
time limit per test:1.5 seconds
memory limit per test:256 megabytes

We saw the little game Marmot made for Mole's lunch. Now it's Marmot's dinner time and, as we all know, Marmot eats flowers. At every dinner he eats some red and white flowers. Therefore a dinner can be represented as a sequence
of several flowers, some of them white and some of them red.

But, for a dinner to be tasty, there is a rule: Marmot wants to eat white flowers only in groups of size
k.

Now Marmot wonders in how many ways he can eat between
a and b flowers. As the number of ways could be very large, print it modulo
1000000007 (109 + 7).

Input

Input contains several test cases.

The first line contains two integers
t and k (1 ≤ t, k ≤ 105), where
t represents the number of test cases.

The next t lines contain two integers
ai and
bi (1 ≤ ai ≤ bi ≤ 105),
describing the i-th test.

Output

Print t lines to the standard output. The
i-th line should contain the number of ways in which Marmot can eat between
ai and
bi flowers at dinner modulo
1000000007 (109 + 7).

Sample test(s)
Input
3 2
1 3
2 3
4 4
Output
6
5
5
Note
  • For K =
    2 and length 1 Marmot can eat (R).
  • For K =
    2 and length 2 Marmot can eat (RR) and (WW).
  • For K =
    2 and length 3 Marmot can eat (RRR), (RWW) and (WWR).
  • For K =
    2 and length 4 Marmot can eat, for example, (WWWW) or (RWWR), but for example he can't eat (WWWR).

题目连接:http://codeforces.com/problemset/problem/474/D

题目大意:一个东西爱吃花,有两种颜色红R和白W。他吃白花每次都一组一组吃,一组是连续在一起的k个,问在花的个数从ai到bi范围里。他总共同拥有多少种吃法

题目分析:dp[i]表示长度为i是他吃花的方案数。初始时dp[i] = 1 (0 <= i < k) i小于k时显然仅仅有一种

当i>=k时,我们dp[i]能够是dp[i - 1]加上一朵红花,或者dp[i - k]加上k朵白花,dp[i] = dp[i - 1] + dp[i - k]

然后求出dp数组的前缀和,查询时O(1)

#include <cstdio>
#include <cstring>
#define ll long long
int const MAX = 1e5 + 5;
int const MOD = 1e9 + 7;
int a[MAX];
ll dp[MAX], sum[MAX]; int main()
{
int t, k;
scanf("%d %d", &t, &k);
for(int i = 0; i < k; i++)
dp[i] = 1;
for(int i = k; i < MAX; i++)
dp[i] = (dp[i - 1] % MOD + dp[i - k] % MOD) % MOD;
sum[1] = dp[1];
for(int i = 2; i < MAX; i++)
sum[i] = (sum[i - 1] % MOD + dp[i] % MOD) % MOD;
while(t --)
{
int a, b;
scanf("%d %d", &a, &b);
printf("%lld\n", (MOD + sum[b] - sum[a - 1]) % MOD);
}
}

最新文章

  1. Java基础---MD5和BASE64
  2. 20个优秀的 JavaScript 键盘事件处理库
  3. EXT学习之——EXT下拉框默认绑定第一个值
  4. jupyter
  5. Linux基础入门(新版)(实验五至实验八)
  6. Android 上下文菜单实现
  7. 正则表达式-delphi
  8. poj 3498 March of the Penguins(最大流+拆点)
  9. Java-io流入门到精通详细总结
  10. Python 学习系列----第一章:基础知识
  11. POJ-2109 Power of Cryptography(数学或二分+高精度)
  12. rapid7/metasploitable3 CTF摘要
  13. 使用CloneDB克隆数据库
  14. c# 服务安装后自动启动
  15. 需求文件requirements.txt的创建及使用
  16. flex布局学习总结
  17. question?
  18. sharePoint查看与更改用户登录账号
  19. 洛谷 P1149 火柴棒等式
  20. [Bug]CS0016: 未能写入输出文件“c:\Windows\Microsoft.NET\Framework\v4.0.30319\Temp

热门文章

  1. bzoj2127: happiness(双倍经验最小割)
  2. iOS菜鸟成长笔记(2)——网易彩票练习
  3. AngularJs轻松入门(一)创建第一个应用
  4. GoldenGate V11.1数据复制限制
  5. iOS-RAC学习笔记(一)——RACStream
  6. apache(XAMPP)禁止IP访问的httpd-vhosts.conf设置
  7. screen---管理会话
  8. caioj 1077 动态规划入门(非常规DP1:筷子)
  9. 紫书 例题 10-6 UVa 1635 (二项式定理+唯一分解定理)
  10. Object-C,四则运算计算器