acgo题库
  • 首页
  • 题库
  • 题单
  • 竞赛
  • 讨论
  • 排行
  • 团队
  • 备赛专区

    竞赛

    • CSP-J/S
    • 蓝桥杯

    考级

    • GESP
    • CPA
    • 电子学会考级
登录
注册
题目详情题解(0)讨论(0)提交记录(0)
  • 不用反向更新?

    看了题解,原来不用反向更新 我是小丑

    userId_undefined

    Xylophone

    荣耀黄金
    6阅读
    0回复
    0点赞
  • 888

    #include <bits/stdc++.h> using namespace std; #define ll long long #define fastio ios::sync_with_stdio(false), cin.tie(NULL), cout.tie(NULL) int main() { fastio; int n; cin >> n; vector<int> dp(n + 1, n - 1); dp[1] = 0; for (int i = 1; i < n; i++) { dp[i + 1] = min(dp[i + 1], dp[i] + 1); for (int j = 1;; j++) // 枚举蓄力时间 { int x = i + j * j; // 蓄力跳跃的落点 if (x > n) break; dp[x] = min(dp[x], dp[i] + j + 1); } } cout << dp[n];

    userId_undefined

    ‮

    荣耀黄金
    6阅读
    0回复
    0点赞
  • 888

    #include <bits/stdc++.h> using namespace std; #define ll long long #define fastio ios::sync_with_stdio(false), cin.tie(NULL), cout.tie(NULL) int main() { fastio; int n; cin >> n; vector<int> dp(n + 1, n - 1); dp[1] = 0; for (int i = 1; i < n; i++) { dp[i + 1] = min(dp[i + 1], dp[i] + 1); for (int j = 1;; j++) // 枚举蓄力时间 { int x = i + j * j; // 蓄力跳跃的落点 if (x > n) break; dp[x] = min(dp[x], dp[i] + j + 1); } } cout << dp[n];

    userId_undefined

    ‮

    荣耀黄金
    2阅读
    0回复
    0点赞
首页