博客
关于我
算法擂台微积分习题问题解答
阅读量:142 次
发布时间:2019-02-27

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

??????n????S?????????????????????????a_i?b_i???????????????????????????

????

  • ?????????????????x_i??????????x? + x? + ? + x_n = S?????a_i ? x_i ? b_i?
  • ?????????????dp???dp[i][j]???i???j???????
  • ????dp[0][0] = 1????0??0????????
  • ??????????i??????x_i????dp???????????????j?dp[i][j + x_i] += dp[i-1][j]?
  • ???????????????????????????
  • ????

    #include 
    #include
    #include
    using namespace std;int main() { int n, S; cin >> n >> S; vector
    a(n), b(n); for (int i = 0; i < n; ++i) { cin >> a[i] >> b[i]; } vector
    dp(S + 1, 0); dp[0] = 1; for (int i = 0; i < n; ++i) { int min_sum = 0, max_sum = 0; for (int j = 0; j <= S; ++j) { if (dp[j] > 0) { min_sum = min(min_sum, j + a[i]); max_sum = max(max_sum, j + b[i]); } } if (max_sum > S) max_sum = S; if (min_sum > S) { dp = vector
    (S + 1, 0); break; } for (int j = max(0, S - max_sum); j <= S; ++j) { int current = j; for (int k = a[i]; k <= b[i]; ++k) { if (current - k >= 0 && dp[current - k] > 0) { dp[current] += dp[current - k]; } } } } cout << dp[S] << endl; return 0;}

    ????

  • ?????????n????S????????a_i?b_i?
  • ??????????dp?????i???j??????????dp[0] = 1?
  • ???????????i?????????x_i??????dp???
  • ?????????j???????????
  • ?????????dp[S]????S???????
  • ???????????????????????????????????????????

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

    你可能感兴趣的文章
    Objective-C ---JSON 解析 和 KVC
    查看>>
    Objective-C 编码规范
    查看>>
    Objective-Cfor循环实现Factorial阶乘算法 (附完整源码)
    查看>>
    Objective-C——判断对象等同性
    查看>>
    objective-c中的内存管理
    查看>>
    Objective-C之成魔之路【7-类、对象和方法】
    查看>>
    Objective-C享元模式(Flyweight)
    查看>>
    Objective-C以递归的方式实现二叉搜索树算法(附完整源码)
    查看>>
    Objective-C内存管理教程和原理剖析(三)
    查看>>
    Objective-C实现 Greedy Best First Search最佳优先搜索算法(附完整源码)
    查看>>
    Objective-C实现 jugglerSequence杂耍者序列算法 (附完整源码)
    查看>>
    Objective-C实现 lattice path格子路径算法(附完整源码)
    查看>>
    Objective-C实现1000 位斐波那契数算法(附完整源码)
    查看>>
    Objective-C实现2 个数字之间的算术几何平均值算法(附完整源码)
    查看>>
    Objective-C实现2d 表面渲染 3d 点算法(附完整源码)
    查看>>
    Objective-C实现2D变换算法(附完整源码)
    查看>>
    Objective-C实现3n+1猜想(附完整源码)
    查看>>
    Objective-C实现3n+1猜想(附完整源码)
    查看>>
    Objective-C实现9x9乘法表算法(附完整源码)
    查看>>
    Objective-C实现9×9二维数组数独算法(附完整源码)
    查看>>