POJ 1015 Jury Compromise (动态规划)
dp[i][j]代表选了i个人,D(J)-P(J)的值为j的状态下,D(J)+P(J)的最大和。
#include <cstdio>
#include <cstring>
#include <cstdlib>
#include <algorithm> using namespace std; const int MAXN = ; int n, m;
int dp[][MAXN];
int path[][MAXN];
int P[], D[];
int sub[], sum[];
int maxval, fix;
int ans[]; bool IfHave( int i, int j, int k )
{
while ( i > )
{
if ( path[i][j] == k ) return true;
j -= sub[ path[i][j] ];
--i;
}
return false;
} void DP()
{
memset( dp, -, sizeof(dp) );
dp[][+fix] = ;
for ( int i = ; i <= m; ++i )
for ( int j = -fix; j <= fix; ++j )
{
if ( dp[i - ][j + fix] >= )
{
for ( int k = ; k <= n; ++k )
{
int newdp = dp[i - ][ j+fix ]+sum[k];
int &curdp = dp[i][ j+fix+sub[k] ];
if ( !IfHave( i-, j+fix, k) && newdp > curdp )
{
path[i][j+fix+sub[k]] = k;
curdp = newdp;
}
}
}
} return;
} void getPath( int i, int j )
{
int cnt = ;
while ( i > )
{
ans[cnt++] = path[i][j];
j -= sub[ path[i][j] ];
--i;
}
return;
} int main()
{
int cas = ;
while ( scanf( "%d%d", &n, &m ) == && (n || m) )
{
for ( int i = ; i <= n; ++i )
{
scanf( "%d%d", &P[i], &D[i] );
sub[i] = P[i] - D[i];
sum[i] = P[i] + D[i];
} fix = * m;
maxval = * fix; DP(); int anssub, anssum;
for ( int i = ; i <= fix; ++i )
if ( dp[m][fix-i] >= || dp[m][fix+i] >= )
{
if ( dp[m][fix-i] > dp[m][fix+i] )
{
anssub = fix-i;
anssum = dp[m][fix-i];
}
else
{
anssub = fix+i;
anssum = dp[m][fix+i];
}
break;
} getPath( m, anssub );
int sum1 = , sum2 = ;
for ( int i = ; i < m; ++i )
{
sum1 += P[ ans[i] ];
sum2 += D[ ans[i] ];
}
printf( "Jury #%d\n", ++cas );
printf( "Best jury has value %d for prosecution and value %d for defence:\n", sum1, sum2 );
sort( ans, ans + m );
for ( int i = ; i < m; ++i )
printf( " %d", ans[i] );
puts("\n");
}
return ;
}
POJ 1015 Jury Compromise (动态规划)的更多相关文章
- 背包系列练习及总结(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 ...
- OpenJudge 2979 陪审团的人选 / Poj 1015 Jury Compromise
1.链接地址: http://bailian.openjudge.cn/practice/2979 http://poj.org/problem?id=1015 2.题目: 总Time Limit: ...
- POJ 1015 Jury Compromise(双塔dp)
Jury Compromise Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 33737 Accepted: 9109 ...
- poj 1015 Jury Compromise(背包+方案输出)
\(Jury Compromise\) \(solution:\) 这道题很有意思,它的状态设得很...奇怪.但是它的数据范围实在是太暴露了.虽然当时还是想了好久好久,出题人设了几个限制(首先要两个的 ...
- POJ 1015 Jury Compromise 2个月后重做,其实这是背包题目
http://poj.org/problem?id=1015 题目大意:在遥远的国家佛罗布尼亚,嫌犯是否有罪,须由陪审团决定.陪审团是由法官从公众中挑选的.先随机挑选n个人作为陪审团的候选人,然后再从 ...
- POJ 1015 Jury Compromise dp分组
第一次做dp分组的问题,百度的~~ http://poj.org/problem?id=1015 题目大意:在遥远的国家佛罗布尼亚,嫌犯是否有罪,须由陪审团决定.陪审团是由法官从公众中挑选的.先随机挑 ...
- [Poj 1015] Jury Compromise 解题报告 (完全背包)
题目链接:http://poj.org/problem?id=1015 题目: 题解: 我们考虑设计DP状态(因为这很显然是一个完全背包问题不是吗?) dp[j][k]表示在外层循环到i时,选了j个人 ...
- POJ #1015 - Jury Compromise - TODO: POJ website issue
(poj.org issue. Not submitted yet) This is a 2D DP problem, very classic too. Since I'm just learnin ...
- HDU POJ 1015 Jury Compromise(陪审团的人选,DP)
题意: 在遥远的国家佛罗布尼亚,嫌犯是否有罪,须由陪审团决定.陪审团是由法官从公众中挑选的.先随机挑选n个人作为陪审团的候选人,然后再从这n个人中选m人组成陪审团.选m人的办法是:控方和辩方会根据对候 ...
随机推荐
- Python基础—07-函数使用(01)
#函数使用 零碎知识 灵活的if-else a = 3 if False else 5 # 等价于 if False: a = 3 else: a = 5 灵活的and/or # 当前面为真,才会进行 ...
- Struts2前期(这框架目前正处于淘汰状态)
Struts2第一天 Struts2的学习路线 1. Struts2的入门:主要是学习Struts2的开发流程(Struts2的开发流程.常见的配置.Action类的编写) 2. Struts2的Se ...
- mysql if...else 的使用
select case when tca.id = '3' then 'vw' else epc_code end as epccode,tfp.product_id, tfp.vender, tfp ...
- Java集合类——Set、List、Map、Queue接口
目录 Java 集合类的基本概念 Java 集合类的层次关系 Java 集合类的应用场景 一. Java集合类的基本概念 在编程中,常需要集中存放多个数据,数组是一个很好的选择,但数组的长度需提前指定 ...
- javascript中几种this指向问题
javascript中几种this指向问题 首先必须要说的是,this 永远指向函数运行时所在的对象,而不是函数被创建时所在的对象. (1).作为函数名调用 函数作为全局对象调用,this指向 ...
- android 按钮动态点击
关键代码: 1.创建一个btn_selector.xml的文件 <?xml version="1.0" encoding="utf-8"?>< ...
- PHP计算两个时间戳之间间隔时分秒
/功能:计算两个时间戳之间相差的日时分秒//$begin_time 开始时间戳//$end_time 结束时间戳function timediff($begin_time,$end_time){ if ...
- Django的aggregate()和annotate()函数的区别
aggregate() aggregate()为所有的QuerySet生成一个汇总值,相当于Count().返回结果类型为Dict. annotate() annotate()为每一个QuerySet ...
- liunx下搭建python开发环境
=============================================================================注意: 在linux下安装新的版本的pytho ...
- linux文件IO操作篇 (一) 非缓冲文件
文件IO操作分为 2 种 非缓冲文件IO 和 缓冲文件IO 它们的接口区别是 非缓冲 open() close() read() write() 缓冲 fopen() fclose() fread() ...