ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

差分约束,背包问题

2022-07-19 21:05:12  阅读:128  来源: 互联网

标签:xj 背包 cout int cin 差分 约束 xi


差分约束,求最大值跑最短路,求最小值跑最长路,

最长路 xi-xj>=k添加j到i的权值为k的边

最短路xi-xj<=k添加j到i的权值为k的边

超级源点,到所有的点权值为0

注意用spfa跑时还要注意是否有负环


背包问题:

01背包

 1 int w[N], v[N];
 2 int f[N];
 3 int main() {
 4     int n, m;
 5     cin >> n >> m;
 6     for (int i = 1; i <= n; ++i)
 7         cin >> w[i] >> v[i];
 8     for (int i = 1; i <= n; ++i) {
 9         for (int j = m; j >= v[i]; --j)//从大往小表示单选
10             f[j] = max(f[j], f[j - v[i]] + w[i]);
11     }
12     cout << f[m] << endl;
13     return 0;
14 }

完全背包

int w[N], v[N];
int f[N];
int main() {
    int n, m;
    cin >> n >> m;
    for (int i = 1; i <= n; ++i)
        cin >> w[i] >> v[i];
    for (int i = 1; i <= n; ++i) {
        for (int j = v[i]; j >= m; ++j)//从小往大表示多选
            f[j] = max(f[j], f[j - v[i]] + w[i]);
    }
    cout << f[m] << endl;
    return 0;
}

多重背包

将他变成多个01背包问题求解就行

标签:xj,背包,cout,int,cin,差分,约束,xi
来源: https://www.cnblogs.com/xuanru/p/16495720.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有