POJ-1015(背包变形+输出路径)
Jury Compromise
POJ-1015
- 推荐几个较好的介绍和理解:https://blog.csdn.net/lyy289065406/article/details/6671105
- https://blog.csdn.net/glqac/article/details/22687243
#include<iostream>
#include<algorithm>
#include<cstring>
#include<string>
#include<cstdio>
using namespace std;
const int INF=0X3F3F3F3F;
const int maxn=203;
const int maxm=22;
int n,m;
int d[maxn],p[maxn];//被告和原告
int add[maxn],sub[maxn];//sub[i]表示辩控差也就是p-d
int dp[maxn][maxm][802];//dp[i][j][k]表示从前i个人里面选择j个人,辩控差为k时的最大值// dp[i,j,k]=max{dp[i-1,j,k],dp[i-1,j-1,k-d[i]]+ad[i]}
int path[maxn][maxm][802];
int ans[maxm];
struct node{
int defence;
int prosecute;
int num;
};
int main(){
int cases=0;
while(cin>>n>>m&&(n||m)){
for(int i=1;i<=n;i++){
cin>>p[i]>>d[i];
add[i]=p[i]+d[i];
sub[i]=p[i]-d[i];
}
memset(dp,-INF,sizeof(dp));
int fix=m*20;//表示修正值
for(int i=0;i<=n;i++){
dp[i][0][fix]=0;////由于修正了数值,因此dp[i][0][fix]才是真正的dp[i][0][0]
}
for(int i=1;i<=n;i++){
for(int j=1;j<=i&&j<=m;j++){
for(int k=0;k<=fix*2;k++){
dp[i][j][k]=dp[i-1][j][k];
path[i][j][k]=path[i-1][j][k];
if(k>=sub[i]&&dp[i-1][j-1][k-sub[i]]>=0&&k-sub[i]<=2*fix){
if(dp[i-1][j-1][k-sub[i]]+add[i]>dp[i][j][k]){
dp[i][j][k]=dp[i-1][j-1][k-sub[i]]+add[i];
path[i][j][k]=i;
}
}
}
}
}
int diff,k;
for(k=0;k<=fix;k++){
if(dp[n][m][fix-k]>=0||dp[n][m][fix+k]>=0){
break;
}
}
if(dp[n][m][fix-k]>dp[n][m][fix+k]){
diff=fix-k;
}else diff=fix+k;
cout<<"Jury #"<< ++cases <<endl;
cout<< "Best jury has value ";
//辩方总值 = (辨控和+辨控差-修正值)/2
cout<<(dp[n][m][diff]+diff-fix)/2<<" for prosecution and value ";
//控方总值 = (辨控和-辨控差+修正值)/2
cout<<(dp[n][m][diff]-diff+fix)/2<<" for defence:"<<endl;
//类似于背包输出路径
for (int i=n,j=m,k=diff; j>=1;)
{
int p = path[i][j][k] ;
ans[j] = p;
k -= sub[p];
j--;
i = path[p-1][j][k];//
}
for (int i=1; i<=m; i++)
{
cout << " " << ans[i];
}
cout<<endl<<endl;
}
return 0;
}
POJ-1015(背包变形+输出路径)的更多相关文章
- Codeforces Round #436 E. Fire(背包dp+输出路径)
题意:失火了,有n个物品,每个物品有价值pi,必须在时间di前(小于di)被救,否则就要被烧毁.救某个物 品需要时间ti,问最多救回多少价值的物品,并输出救物品的顺序. Examples Input ...
- 迷宫问题 POJ - 3984 (搜索输出路径)
题目大意 题目不需要大意,poj居然还有中文题 鸣谢 特别鸣谢ljc大佬提供的方法!!! 解法 我们可能输出个最短路径的长度比较简单,但是输出最短路径真的是没有做过,这里有一种简单的方法 因为我们的d ...
- Catenyms POJ - 2337(单词+字典序输出路径)
题意: 就是给出几个单词 看能否组成欧拉回路或路径 当然还是让输出组成的最小字典序的路 解析: 还是把首尾字母看成点 把单词看成边 记录边就好了 这题让我对fleury输出最小字典序又加深了一些 ...
- poj 3414 Pots(bfs+输出路径)
Description You are given two pots, having the volume of A and B liters respectively. The following ...
- uva624 01背包要求输出路径
You have a long drive by car ahead. You have a tape recorder, but unfortunately your best music is o ...
- 背包系列练习及总结(hud 2602 && hdu 2844 Coins && hdu 2159 && poj 1170 Shopping Offers && hdu 3092 Least common multiple && poj 1015 Jury Compromise)
作为一个oier,以及大学acm党背包是必不可少的一部分.好久没做背包类动规了.久违地练习下-.- dd__engi的背包九讲:http://love-oriented.com/pack/ 鸣谢htt ...
- VJP1071新年趣事之打牌(背包+输出路径)
简单的01背包 保存下方案总数 其实就是dp[v]值 输出路径dfs一下 #include <iostream> #include<cstdio> #include<cs ...
- UVA-624 CD---01背包+输出路径
题目链接: https://vjudge.net/problem/UVA-624 题目大意: 这道题给定一个时间上限,然后一个数字N,后面跟着N首歌的时间长度,要我们 求在规定时间w内每首歌都要完整的 ...
- Codeforces Gym-102219 2019 ICPC Malaysia National E. Optimal Slots(01背包+输出路径)
题意:给你一个体积为\(T\)的背包,有\(n\)个物品,每个物品的价值和体积都是是\(a_{i}\),求放哪几个物品使得总价值最大,输出它们,并且输出价值的最大值. 题解:其实就是一个01背包输出路 ...
随机推荐
- Codeforces #6241 div2 C. Orac and LCM (数学)
题意:给你一个数列,求所有子序列对的\(lcm\),然后求这些所有\(lcm\)的\(gcd\). 题解:我们对所有数分解质因数,这里我们首先要知道一个定理: 对于\(n\)个数,假如某个质数\( ...
- Proud Merchants HDU - 3466 01背包&&贪心
最近,我去了一个古老的国家.在很长一段时间里,它是世界上最富有.最强大的王国.结果,这个国家的人民仍然非常自豪,即使他们的国家不再那么富有.商人是最典型的,他们每个人只卖一件商品,价格是Pi,但是如果 ...
- 部署开源IP管理工具phpIPAM
一.安装环境程序: yum install httpd mariadb-server php php-cli php-gd php-common php-ldap php-pdo php-pear p ...
- 2.了解nginx常用的配置
作者 微信:tangy8080 电子邮箱:914661180@qq.com 更新时间:2019-07-10 20:56:10 星期三 欢迎您订阅和分享我的订阅号,订阅号内会不定期分享一些我自己学习过程 ...
- ACM-ICPC 2018 徐州赛区网络预赛 B BE, GE or NE 【模拟+博弈】
题目:戳这里 题意:A和B博弈,三种操作分别是x:加a,y:减b,z:取相反数.当x或y或z为0,说明该操作不可取,数据保证至少有一个操作可取,给定一个区间(l,k)和原始数字m,如果A和B在n次操作 ...
- 2017CCCC决赛 L1-3. 阅览室
L1-3 阅览室(20 分) 天梯图书阅览室请你编写一个简单的图书借阅统计程序.当读者借书时,管理员输入书号并按下S键,程序开始计时:当读者还书时,管理员输入书号并按下E键,程序结束计时.书号为不超过 ...
- 80行Python代码搞定全国区划代码
微信搜索:码农StayUp 主页地址:https://gozhuyinglong.github.io 源码分享:https://github.com/gozhuyinglong/blog-demos ...
- PostCSS All In One
PostCSS All In One https://postcss.org/ https://www.webpackjs.com/loaders/postcss-loader/ https://gi ...
- GitHub Secrets All In One
GitHub Secrets All In One https://docs.github.com/en/free-pro-team@latest/actions/reference/encrypte ...
- LeetCode 二叉树,两个子节点的最近的公共父节点
LeetCode 二叉树,两个子节点的最近的公共父节点 二叉树 Lowest Common Ancestor of a Binary Tree 二叉树的最近公共父亲节点 https://leetcod ...