记录编号 577182 评测结果 AAAAAAAAAA
题目名称 [LOJ β Round]ZQC 的拼图 最终得分 100
用户昵称 Gravatarlihaoze 是否通过 通过
代码语言 C++ 运行时间 0.051 s
提交时间 2022-10-24 23:18:08 内存使用 1.16 MiB
显示代码纯文本
  1. #include "bits/stdc++.h"
  2.  
  3. const int N = 110;
  4. int n, m;
  5. int f[N][N];
  6. int a[N], b[N];
  7. // f[i, j]: 第 i 个积木,枚举到横坐标 j 时 y_i 的最大值
  8.  
  9. bool check(int x) {
  10. memset(f, -0x3f, sizeof f);
  11. f[0][0] = 0;
  12. for (int i = 1; i <= n; ++ i)
  13. for (int j = 0; j <= m; ++ j) {
  14. f[i][j] = -1e9;
  15. for (int k = std::max(0, j - x / a[i]); k <= j; ++ k)
  16. f[i][j] = std::max(f[i][j], f[i - 1][k] + (x - a[i] * (j - k)) / b[i]);
  17. }
  18. return f[n][m] >= m;
  19. }
  20.  
  21. int main() {
  22. freopen("jigsaw.in", "r", stdin);
  23. freopen("jigsaw.out", "w", stdout);
  24. std::cin >> n >> m;
  25. for (int i = 1; i <= n; ++ i) {
  26. std::cin >> a[i] >> b[i];
  27. }
  28. int l = 1, r = 1e7;
  29. while (l < r) {
  30. int mid = l + r >> 1;
  31. if (check(mid)) r = mid;
  32. else l = mid + 1;
  33. }
  34. std::cout << l << '\n';
  35. return 0;
  36. }