POJ 1015 Jury Compromise(DP)
来源:互联网 发布:ember.js 开发工具 编辑:程序博客网 时间:2024/06/03 11:17
题意:每个人有a, b两个值,现在从n个人选出m个人,使得a和b的总和之差绝对值最小,如果有多解,输出a和b总和的和最大的解
思路:dp[i][j][k]表明选到第i个人,选了j个人,差为k的解的总和最大值,然后转移最后找一下解即可
代码:
#include <cstdio>#include <cstring>#include <cstdlib>const int N = 205;const int M = 25;const int INF = 0x3f3f3f3f;int n, m, d[N], p[N], dp[N][M][805], path[N][M][805], out[M], on;int main() { int cas = 0; while (~scanf("%d%d", &n, &m) && n || m) {for (int i = 0; i <= n; i++) for (int j = 0; j <= m; j++)for (int k = 0; k <= 800; k++) dp[i][j][k] = -INF;dp[0][0][400] = 0;for (int i = 1; i <= n; i++) { scanf("%d%d", &d[i], &p[i]); for (int j = 0; j <=m; j++) {for (int k = 0; k <= 800; k++) { if (dp[i][j][k] < dp[i - 1][j][k]) {dp[i][j][k] = dp[i - 1][j][k];path[i][j][k] = 0; } if (j == 0) continue; int pre = k - d[i] + p[i]; if (pre < 0 || pre > 800 || dp[i - 1][j - 1][pre] == -INF) continue; if (dp[i][j][k] < dp[i - 1][j - 1][pre] + d[i] + p[i]) {dp[i][j][k] = dp[i - 1][j - 1][pre] + d[i] + p[i];path[i][j][k] = i; }} }}int ans = INF, ansv;for (int i = 0; i <= 800; i++) { if (dp[n][m][i] != -INF && ans > abs(i - 400)) {ans = abs(i - 400);ansv = i; } else if (ans == abs(i - 400)) {if (dp[n][m][i] > dp[n][m][ansv]) ansv = i; }}int ans1 = 0, ans2 = 0;on = 0;while (n) { int tmp = path[n][m][ansv]; if (tmp) {out[on++] = tmp;n--;m--;ansv = ansv - d[tmp] + p[tmp];ans1 += d[tmp];ans2 += p[tmp]; } elsen--;}printf("Jury #%d\n", ++cas);printf("Best jury has value %d for prosecution and value %d for defence:\n", ans1, ans2);for (int i = on - 1; i >= 0; i--) printf(" %d", out[i]);printf("\n\n"); } return 0;}
0 0
- poj - 1015 - Jury Compromise(dp)
- POJ 1015 Jury Compromise(DP)
- POJ 1015 Jury Compromise(双塔DP)
- POJ 1015 Jury Compromise (dp)
- [dp] poj 1015 Jury Compromise
- poj 1015 Jury Compromise dp
- POJ 1015 Jury Compromise(DP)
- POJ 1015 Jury Compromise ---- DP
- DP-POJ-1015-Jury Compromise
- POJ 1015 Jury Compromise【DP】
- poj Jury Compromise 1015 (DP) 好题
- POJ 1015 Jury Compromise 双塔DP
- POJ 1015 Jury Compromise DP+记录路径
- POJ 1015 Jury Compromise(DP+回溯)
- POJ 1015 Jury Compromise
- poj 1015 Jury Compromise
- POJ 1015 Jury Compromise
- poj 1015Jury Compromise
- [Leetcode]Same Tree
- SQL优化
- 《你必须知道的495个C语言问题》笔记--自己的
- 欧公《晋祠》
- 解决PLSQL 连接数据库 ORA-12154 TNS无法解析指定的连接标识符
- POJ 1015 Jury Compromise(DP)
- json返回日期格式化
- C++11 lambda 表达式解析
- IOS颜色转换swift和objective-C版
- js中利用offset()来相对定位
- android获得控件在屏幕中的绝对坐标 getLocationInWindow 和 getLocationOnScreen
- 微信之父演讲谈2015年微商之路如何赚钱
- eclipse中 一个工程引用另一个工程设置
- 高仿网易评论列表效果之界面生成