Codeforces 474D - Flowers(0 - 1背包)

题意

小明要吃花。

他只能吃k朵连着的白色花,不然就不吃,问花有a~b朵的时候有几种情况

思路

就是一个简单的背包

dp[i]=dp[i1]+dp[ik]

有i朵花的时候,要么增加一朵红花,这时候是dp[i - 1]种情况,也可以增加k朵白花,dp[i - k]种情况。

比赛的时候我竟然写了排列组合,妥妥的TLE。

代码

  
  
  
  
  1. #include <cstdio>
  2. #include <stack>
  3. #include <set>
  4. #include <iostream>
  5. #include <string>
  6. #include <vector>
  7. #include <queue>
  8. #include <functional>
  9. #include <cstring>
  10. #include <algorithm>
  11. #include <cctype>
  12. #include <ctime>
  13. #include <cstdlib>
  14. #include <fstream>
  15. #include <string>
  16. #include <sstream>
  17. #include <map>
  18. #include <cmath>
  19. #define LL long long
  20. #define SZ(x) (int)x.size()
  21. #define Lowbit(x) ((x) & (-x))
  22. #define MP(a, b) make_pair(a, b)
  23. #define MS(arr, num) memset(arr, num, sizeof(arr))
  24. #define PB push_back
  25. #define F first
  26. #define S second
  27. #define ROP freopen("input.txt", "r", stdin);
  28. #define MID(a, b) (a + ((b - a) >> 1))
  29. #define LC rt << 1, l, mid
  30. #define RC rt << 1|1, mid + 1, r
  31. #define LRT rt << 1
  32. #define RRT rt << 1|1
  33. #define BitCount(x) __builtin_popcount(x)
  34. const double PI = acos(-1.0);
  35. const int INF = 0x3f3f3f3f;
  36. using namespace std;
  37. const int MAXN = 1e5 + 10;
  38. const int MOD = 1e9 + 7;
  39. typedef pair<int, int> pii;
  40. typedef vector<int>::iterator viti;
  41. typedef vector<pii>::iterator vitii;
  42. LL dp[MAXN];
  43. int main()
  44. {
  45. //ROP;
  46. ios::sync_with_stdio(0);
  47. int n, k, i, j;
  48. cin >> n >> k;
  49. dp[0] = 1;
  50. for (i = 1; i < MAXN; i++) dp[i] = (dp[i - 1] + (i >= k ? dp[i - k] : 0)) % MOD;
  51. for (i = 2; i < MAXN; i++) dp[i] = (dp[i - 1] + dp[i]) % MOD;
  52. dp[0] = 0;
  53. while (n--)
  54. {
  55. int a, b;
  56. cin >> a >> b;
  57. cout << (dp[b] - dp[a - 1] + MOD) % MOD << endl;
  58. }
  59. return 0;
  60. }

你可能感兴趣的:(ACM,codeforces)