题目不难,暴力地dp一下就好,但是不知道我WA在哪里了,对拍了好多的数据都没找出错误= =。估计又是哪里小细节写错了QAQ。。思路是用dp[i][j]表示已经选了i个,差值为j的最大和。转移的话暴力枚举当前选那个即可。代码如下(WA的,以后有机会再找找错在哪里吧0.0):

 #include <stdio.h>
#include <algorithm>
#include <string.h>
#include <set>
using namespace std;
const int N = + ; int n,m;
int a[N],b[N];
struct node
{
int now,pre,val;
int a,b;
}dp[+][+]; set<int> get(int x)
{
set<int> S;
for(int i=m;i>=;i--)
{
S.insert(dp[i][x].now);
x = dp[i][x].pre;
}
return S;
} int main()
{
int kase = ;
while(scanf("%d%d",&n,&m) == )
{
if(n == & m == ) break;
for(int i=;i<=n;i++) scanf("%d%d",a+i,b+i);
for(int i=;i<=;i++) dp[][i] = (node){-,-,,,};
dp[][] = (node){,-,,,};
for(int i=;i<=m;i++)
{
for(int j=;j<=;j++)
{
dp[i][j] = (node){-,-,,,};
for(int k=;k<=n;k++)
{
int add = a[k] - b[k];
if(j-add < || j - add > ) continue;
int pre = j - add;
if(dp[i-][pre].now == -) continue;
int flag = ;
for(int p=i-;p>=;p--)
{
if(dp[p][pre].now == k)
{
flag = ;
break;
}
else pre = dp[p][pre].pre;
}
if(flag == ) continue;
if(dp[i-][j - add].val + a[k]+b[k] > dp[i][j].val)
{
dp[i][j] = (node){k,j-add,dp[i-][j - add].val + a[k]+b[k],
dp[i-][j - add].a + a[k], dp[i-][j - add].b + b[k]};
}
}
}
}
set<int> S;
int aa, bb;
for(int add=;add<=;add++)
{
if(dp[m][-add].now == - && dp[m][+add].now == -) continue;
int temp = ;
if(dp[m][-add].now != -)
{
temp = dp[m][-add].val;
S = get(-add);
aa = dp[m][-add].a, bb = dp[m][-add].b;
}
if(dp[m][+add].now != -)
{
if(dp[m][+add].val > temp)
{
S = get(+add);
aa = dp[m][+add].a, bb = dp[m][+add].b;
}
}
break;
}
printf("Jury #%d\n",kase++);
printf("Best jury has value %d for prosecution and value %d for defence:\n",aa,bb);
for(set<int>::iterator it=S.begin();it!=S.end();it++) printf(" %d",*it);
puts("\n");
}
return ;
}

POJ 1051 Jury Compromise ——(暴力DP)的更多相关文章

  1. POJ 1015 Jury Compromise(dp坑)

    提议:在遥远的国家佛罗布尼亚,嫌犯是否有罪,须由陪审团决定.陪审团是由法官从公众中挑选的.先随机挑选n个人作为陪审团的候选人,然后再从这n个人中选m人组成陪审团.选m人的办法是:控方和辩方会根据对候选 ...

  2. POJ 1015 Jury Compromise【DP】

    罗大神说这题很简单,,,,然而我着实写的很难过... 题目链接: http://acm.hust.edu.cn/vjudge/contest/view.action?cid=110495#proble ...

  3. 背包系列练习及总结(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 ...

  4. 【题解】Jury Compromise(链表+DP)

    [题解]Jury Compromise(链表+DP) 传送门 题目大意 给你\(n\le 200\)个元素,一个元素有两个特征值,\(c_i\)和\(d_i\),\(c,d \in [0,20]\), ...

  5. POJ 1015 Jury Compromise(双塔dp)

    Jury Compromise Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 33737   Accepted: 9109 ...

  6. OpenJudge 2979 陪审团的人选 / Poj 1015 Jury Compromise

    1.链接地址: http://bailian.openjudge.cn/practice/2979 http://poj.org/problem?id=1015 2.题目: 总Time Limit: ...

  7. poj 1015 Jury Compromise(背包+方案输出)

    \(Jury Compromise\) \(solution:\) 这道题很有意思,它的状态设得很...奇怪.但是它的数据范围实在是太暴露了.虽然当时还是想了好久好久,出题人设了几个限制(首先要两个的 ...

  8. POJ 1015 Jury Compromise dp分组

    第一次做dp分组的问题,百度的~~ http://poj.org/problem?id=1015 题目大意:在遥远的国家佛罗布尼亚,嫌犯是否有罪,须由陪审团决定.陪审团是由法官从公众中挑选的.先随机挑 ...

  9. poj 1015 Jury Compromise(背包变形dp)

    In Frobnia, a far-away country, the verdicts in court trials are determined by a jury consisting of ...

随机推荐

  1. express 和 vue-cli 的博客网站

    已经上传到github地址:https://github.com/13476075014/node-vue/tree/master/mynodeproject/15.TimeBlog # 个人博客系统 ...

  2. redis cluster异地数据迁移,扩容,缩容

    由于项目的服务器分布在重庆,上海,台北,休斯顿,所以需要做异地容灾需求.当前的mysql,redis cluster,elastic search都在重庆的如果重庆停电了,整个应用都不能用了. 现在考 ...

  3. ARC模式下获取retainCount的方法

    _objc_rootRetainCount(obj)可以获取obj的retainCount,不过不清楚是不是私有api,因此建议调试时使用.

  4. 5.管道 Pipe

    /*管道(Pipe)*/ Java NIO 管道是 /*2 个线程*/ 之间的 /*单向*/数据连接 Pipe 有一个 source 通道 和 一个 sink 通道.数据会被写到 sink 通道,从s ...

  5. LVS、nginx、Haproxy对比(详细)

    目录 代理软件 负载均衡产品介绍 haproxy 本文档参考 http://www.ha97.com/5646.html 代理软件 负载均衡产品介绍 市面上的负载均衡产品主要分为两种:硬件产品和软件产 ...

  6. java - day009 - 基础API,object,String, StringBuilder/StringBuffer, 正则表达式

    API java.lang.object object 所有类的顶层父类 一个类如果不继承其他类,默认继承object.    toString() 获得一个对象的字符串表示     可以重写     ...

  7. html和css的一些常用标签使用

    HTML(HyperText Mark-up Language)超文本标签语言 <!DOCTYPE html> <!--声明这是一个html文档--> <html> ...

  8. 搭建nginx文件服务器

    一.安装nginx服务 apt install nginx 二.修改nginx配置文件 cd /etc/nginx/conf.d/ vim download_server.conf server { ...

  9. jquery 选择器能否查找display:none的元素

    jQuery可以用可见性“:hidden”查找“display:none”的元素. 1.新家html文档,在head标签中引入本地jQuery文件,也可以引入cdn文件: 2.在body标签中添加一些 ...

  10. python 杂记 网络

    参考资料:https://www.cnblogs.com/gareth-yu/p/9097943.htmlimport selectors import socket sel = selectors. ...