博客
关于我
算法擂台微积分习题问题解答
阅读量: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/

    你可能感兴趣的文章
    Passport 密码模式
    查看>>
    Spring Boot(七十六):集成Redisson实现布隆过滤器(Bloom Filter)
    查看>>
    passwd命令限制用户密码到期时间
    查看>>
    Spring @Async执行异步方法的简单使用
    查看>>
    PAT (Basic Level) Practice 乙级1021-1030
    查看>>
    PAT (Basic Level) Practice 乙级1031-1040
    查看>>
    PAT (Basic Level) Practice 乙级1041-1045
    查看>>
    SparkSql的元数据
    查看>>
    PAT (Basic Level) Practice 乙级1051-1055
    查看>>
    PAT (Basic Level) Practise - 写出这个数
    查看>>
    PAT 1027 Colors in Mars
    查看>>
    PAT 1127 ZigZagging on a Tree[难]
    查看>>
    PAT 2-07. 素因子分解(20)
    查看>>
    SparkSQL学习03-数据读取与存储
    查看>>
    PAT L2-012. 关于堆的判断
    查看>>
    PAT Spell It Right [非常简单]
    查看>>
    PAT-1044. Shopping in Mars (25)
    查看>>
    PAT-乙级-1040 有几个PAT
    查看>>
    Spring组件扫描配置
    查看>>
    PAT1093 Count PAT's (25)(逻辑题)
    查看>>