博客
关于我
ZOJ2972 Hurdles of 110m(DP)
阅读量:391 次
发布时间:2019-03-05

本文共 2280 字,大约阅读时间需要 7 分钟。

???????????????N??????????????????????????????????????????????????????????????????????????

??????????????????????????T??????????????N?M?????N??????????T1?T2?T3?F1?F2????

  • T1??????????
  • T2??????????
  • T3??????????
  • F1???????????????/??
  • F2???????????????/??

???????????????????????????

????????????DP???????????????????dp???dp[i][j]?????i????????j???????????

?????

  • ????dp[0][0] = 0?????0???????0?
  • ??????i????????????
    • ???????????j >= F1??dp[i][j - F1] = min(dp[i][j - F1], dp[i-1][j] + T1)?
    • ?????dp[i][j] = min(dp[i][j], dp[i-1][j] + T2)?
    • ?????dp[i][min(j + F2, M)] = min(dp[i][min(j + F2, M)], dp[i-1][j] + T3)?
  • ??????????dp[N][j]?????????????
  • ?????

    #include 
    using namespace std;typedef long long ll;const int maxn = 2001;const int inf = 0x3f3f3f3f;int main() { int T, n, m; scanf("%d", &T); while (T--) { scanf("%d %d", &n, &m); vector
    t1(n + 1), t2(n + 1), t3(n + 1); vector
    f1(n + 1), f2(n + 1); for (int i = 1; i <= n; ++i) { int T1, T2, T3, F1, F2; scanf("%d %d %d %d %d", &T1, &T2, &T3, &F1, &F2); t1[i] = T1; t2[i] = T2; t3[i] = T3; f1[i] = F1; f2[i] = F2; } vector
    dp(m + 1, inf); dp[0] = 0; for (int i = 1; i <= n; ++i) { vector
    new_dp(m + 1, inf); for (int j = 0; j <= m; ++j) { if (j >= f1[i]) { if (new_dp[j - f1[i]] > dp[j] + t1[i]) { new_dp[j - f1[i]] = dp[j] + t1[i]; } } if (new_dp[j] > dp[j] + t2[i]) { new_dp[j] = dp[j] + t2[i]; } int next_j = min(j + f2[i], m); if (new_dp[next_j] > dp[j] + t3[i]) { new_dp[next_j] = dp[j] + t3[i]; } } dp = new_dp; } int ans = inf; for (int j = 0; j <= m; ++j) { if (dp[j] < ans) { ans = dp[j]; } } printf("%d\n", ans); }}

    ?????

  • ??????????????????T????????N?M???????????
  • DP??????dp[j]?????i???????j?????
  • ?????????????????????DP???
  • ?????????????????????
  • ????????????????????????????????

    转载地址:http://hhewz.baihongyu.com/

    你可能感兴趣的文章
    Objective-C实现MSRCR算法(附完整源码)
    查看>>
    Objective-C实现multilayer perceptron classifier多层感知器分类器算法(附完整源码)
    查看>>
    Objective-C实现multiplesThreeAndFive三或五倍数的算法 (附完整源码)
    查看>>
    Objective-C实现n body simulationn体模拟算法(附完整源码)
    查看>>
    Objective-C实现naive string search字符串搜索算法(附完整源码)
    查看>>
    Objective-C实现natural sort自然排序算法(附完整源码)
    查看>>
    Objective-C实现nested brackets嵌套括号算法(附完整源码)
    查看>>
    Objective-C实现nevilles method多项式插值算法(附完整源码)
    查看>>
    Objective-C实现newtons second law of motion牛顿第二运动定律算法(附完整源码)
    查看>>
    Objective-C实现newton_forward_interpolation牛顿前插算法(附完整源码)
    查看>>
    Objective-C实现newton_raphson牛顿拉夫森算法(附完整源码)
    查看>>
    Objective-C实现NLP中文分词(附完整源码)
    查看>>
    Objective-C实现NLP中文分词(附完整源码)
    查看>>
    Objective-C实现NMS非极大值抑制(附完整源码)
    查看>>
    Objective-C实现not gate非门算法(附完整源码)
    查看>>
    Objective-C实现number of digits解字符数算法(附完整源码)
    查看>>
    Objective-C实现NumberOfIslands岛屿的个数算法(附完整源码)
    查看>>
    Objective-C实现numerical integration数值积分算法(附完整源码)
    查看>>
    Objective-C实现n皇后问题算法(附完整源码)
    查看>>
    Objective-C实现O(E + V) 中找到 0-1-graph 中的最短路径算法(附完整源码)
    查看>>