Jury Compromise(poj 1015)
描述在遥远的国家佛罗布尼亚,嫌犯是否有罪,须由陪审团决定。陪审团是由法官从公众中挑选的。先随机挑选n个人作为陪审团的候选人,然后再从这n个人中选m人组成陪审团。选m人的办法是:
控方和辩方会根据对候选人的喜欢程度,给所有候选人打分,分值从0到20。为了公平起见,法官选出陪审团的原则是:选出的m个人,必须满足辩方总分和控方总分的差的绝对值最小。如果有多种选择方案的辩方总分和控方总分的之差的绝对值相同,那么选辩控双方总分之和最大的方案即可。输入输入包含多组数据。每组数据的第一行是两个整数n和m,n是候选人数目,m是陪审团人数。注意,1<=n<=200, 1<=m<=20 而且 m<=n。接下来的n行,每行表示一个候选人的信息,它包含2个整数,先后是控方和辩方对该候选人的打分。候选人按出现的先后从1开始编号。两组有效数据之间以空行分隔。最后一组数据n=m=0输出对每组数据,先输出一行,表示答案所属的组号,如 'Jury #1', 'Jury #2', 等。接下来的一行要象例子那样输出陪审团的控方总分和辩方总分。再下来一行要以升序输出陪审团里每个成员的编号,两个成员编号之间用空格分隔。每组输出数据须以一个空行结束。样例输入
4 2
1 2
2 3
4 1
6 2
0 0
样例输出
Jury #1
Best jury has value 6 for prosecution and value 4 for defence:
2 3
/*
自己写了一个三维状态的f[i][j][k]表示前i个选了j个,相差k的最大值,但是无奈怎么也过不去。
题解设的是二维的,把第一位去掉了,转移比较巧妙。
*/
#include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
#define N 310
#define M 1010
using namespace std;
int f[N][M],pa[N][M];;
int a[N],b[N],Answer[N],n,m,Cas; int main(){
while(scanf("%d%d",&n,&m)){
if(n==&&m==) break;
for(int i=;i<=n;i++) scanf("%d%d",&a[i],&b[i]);
memset(f,-,sizeof(f));
memset(pa,,sizeof(pa));
int base=m*;
f[][base]=;
for(int j=;j<m;j++)
for(int k=;k<=base*;k++)
if(f[j][k]>=){
for(int i=;i<=n;i++)
if(f[j][k]+a[i]+b[i]>f[j+][k+a[i]-b[i]]){
int t1=j,t2=k;
while(t1>&&pa[t1][t2]!=i){
t2-=a[pa[t1][t2]]-b[pa[t1][t2]];
t1--;
}
if(t1==){
f[j+][k+a[i]-b[i]]=f[j][k]+a[i]+b[i];
pa[j+][k+a[i]-b[i]]=i;
}
}
}
int i=base,j=,k;
while(f[m][i+j]<&&f[m][i-j]<) j++;
if(f[m][i+j]>f[m][i-j]) k=i+j;
else k=i-j;
printf("Jury #%d\n",++Cas);
printf("Best jury has value %d for prosecution and value %d for defence:\n",(k-base+f[m][k])/,(f[m][k]-k+base)/);
for(i=;i<=m;i++)
{
Answer[i]=pa[m-i+][k];
k-=a[Answer[i]]-b[Answer[i]];
}
sort(Answer+,Answer+m+);
for(i=;i<=m;i++)
printf(" %d",Answer[i]);
printf("\n\n");
}
}
Jury Compromise(poj 1015)的更多相关文章
- (最优m个候选人 和他们的编号)Jury Compromise (POJ 1015) 难
		
http://poj.org/problem?id=1015 Description In Frobnia, a far-away country, the verdicts in court t ...
 - (记忆化搜索)Jury Compromise (poj 1015)
		
http://acm.fzu.edu.cn/problem.php?pid=1005 Description The fastfood chain McBurger owns several rest ...
 - POJ 1015 Jury Compromise(双塔dp)
		
Jury Compromise Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 33737 Accepted: 9109 ...
 - POJ 1015 Jury Compromise(dp坑)
		
提议:在遥远的国家佛罗布尼亚,嫌犯是否有罪,须由陪审团决定.陪审团是由法官从公众中挑选的.先随机挑选n个人作为陪审团的候选人,然后再从这n个人中选m人组成陪审团.选m人的办法是:控方和辩方会根据对候选 ...
 - POJ 1051 Jury Compromise  ——(暴力DP)
		
题目不难,暴力地dp一下就好,但是不知道我WA在哪里了,对拍了好多的数据都没找出错误= =.估计又是哪里小细节写错了QAQ..思路是用dp[i][j]表示已经选了i个,差值为j的最大和.转移的话暴力枚 ...
 - POJ1015 && UVA - 323 ~Jury Compromise(dp路径)
		
In Frobnia, a far-away country, the verdicts in court trials are determined by a jury consisting of ...
 - poj 1015 Jury Compromise(背包+方案输出)
		
\(Jury Compromise\) \(solution:\) 这道题很有意思,它的状态设得很...奇怪.但是它的数据范围实在是太暴露了.虽然当时还是想了好久好久,出题人设了几个限制(首先要两个的 ...
 - 01背包问题:Charm Bracelet (POJ 3624)(外加一个常数的优化)
		
Charm Bracelet POJ 3624 就是一道典型的01背包问题: #include<iostream> #include<stdio.h> #include& ...
 - Scout YYF I(POJ 3744)
		
Scout YYF I Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 5565 Accepted: 1553 Descr ...
 
随机推荐
- Python小项目之五子棋
			
1.项目简介 在刚刚学习完python套接字的时候做的一个五子棋小游戏,可以在局域网内双人对战,也可以和电脑对战 2.实现思路 局域网对战 对于局域网功能来说,首先建立连接(tcp),然后每次下棋时将 ...
 - 37.VUE学习之-表单的综合运用
			
<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <meta http ...
 - 模块之 logging模块 time 模块  random模块 sys模块 pickle模块
			
1.如果执行文件不在项目根目录下,需要添加项目根目录到sys.path中2.调用业务逻辑 2.logging模块 程序日志是 什么时间发生了什么事情,以及当时的情况 不是logging的话 记录日志的 ...
 - relu函数是否存在梯度消失问题以及relu函数的死亡节点问题
			
relu函数是否存在梯度消失问题以及relu函数的死亡节点问题 存在,在小于的时候,激活函数梯度为零,梯度消失,神经元不更新,变成了死亡节点. 出现这个原因可能是因为学习率太大,导致w更新巨大,使得输 ...
 - python2与python3的区别,以及注释、变量、常量与编码发展
			
python2与python3的区别 宏观上: python2:源码不统一,混乱,重复代码太多. python3:源码统一标准,能去除重复代码. 编码上: python2:默认编码方式为ASCII码. ...
 - Python开发不可不知的虚拟环境
			
一.python3.3之后自带的venv模块 1. 创建虚拟环境 python3.6 -m venv project-env 2. 加入虚拟环境目录 cd pronject-env 3. 激活虚拟环境 ...
 - Winform VS2015打包
			
首先 ,我们要去官网http://learn.flexerasoftware.com/content/IS-EVAL-InstallShield-Limited-Edition-Visual-Stud ...
 - Java面向对象---方法的创建与重载
			
方法的创建 方法就是可重复调用的代码段. 定义: 访问修饰符 返回值类型 方法名(参数){ 方法主体 } 返回值类型:void(无返回值):基本数据类型:应用数据类型:类对象等. 方法名的命名规则:第 ...
 - 谋哥:App开发者的苦逼不值得怜悯!
			
[谋哥每天一干货,第四十篇] 为什么取这个标题呢?因为昨天一些本来“支持”谋哥的人看到谋哥搞收费VIP群,觉得谋哥赚苦逼开发者的钱很不道德,且说谋哥我写的东西都不切实际,全部是一些思想性 ...
 - Robotium测试报告的生成方法(上)
			
7.1 使用junit-report生成报告 这个是参考网上的:http://www.xuebuyuan.com/2148574.html,经我个人验证是可行的方法,网上写的挺详细的,不过有些不太清楚 ...