题目:http://poj.org/problem?id=1015

DP的第一维是选了几个人,第二维是当前D与P的差值,而值存的是当前D与P的和;

技巧1:通过平移避免负角标,即代码中的fix;

技巧2:做完DP后找出最小的差的绝对值时,如下的那一小段代码很有效率;

技巧3(*):记录路径——①更新路径时每次判断是否重复选了一个人,重复则不更新;

if(f[j][k]+P[i]+D[i]>f[j+][k+P[i]-D[i]])
{
t1=j;t2=k;
while(t1>&&Path[t1][t2]!=i)//验证i是否在前面出现过
{
t2-=P[Path[t1][t2]]-D[Path[t1][t2]];
t1--;
}
if(t1==)
{
f[j+][k+P[i]-D[i]]=f[j][k]+P[i]+D[i];
Path[j+][k+P[i]-D[i]]=i;
}
}

记录路径1(转)

        int tmp=mk;
for(int j=m;j>;j--)
{
int pr=pre[j][tmp];
ans[j]=pr;
tmp-=(a[pr]-b[pr]);
}
sort(ans+,ans+m+);

记录路径1配套输出

             ②使用vector,每次更新暴力复制;(下面采用)

if(dp[i+][j+subtraction[k]] <= dp[i][j] + _plus[k])
{
dp[i+][j+subtraction[k]] = dp[i][j] + _plus[k];
path[i+][j+subtraction[k]] = path[i][j];//每次更新都要把path全部复制过来,就是因为这个才用的vector
path[i+][j+subtraction[k]].push_back(k);
}

记录路径2(转)

注意:(不知为何)DP顺序,必须是i+1被i更新,原来写的是i被i-1更新,一直WA。

代码如下:

#include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
#include<vector>
using namespace std;
int n,m,a[],b[],f[][],fix,t,ans[];
vector<int>pre[][];
int main()
{
while(scanf("%d%d",&n,&m)==)
{
t++;
memset(f,-,sizeof f);
memset(ans,,sizeof ans);
memset(pre,,sizeof pre);
if(!n&&!m)return ;
for(int i=;i<=n;i++)
scanf("%d%d",&a[i],&b[i]);
fix=*m;
// for(int k=0;k<=2*fix;k++)f[0][k]=0;
f[][fix]=;
for(int i=;i<=n;i++)//第i个人
for(int j=m-;j>=;j--)//选了j个
for(int k=;k<=*fix;k++)
{
// if(f[j-1][k-a[i]+b[i]]<0)continue;//
// if(f[j][k]<f[j-1][k-a[i]+b[i]]+a[i]+b[i])
// {
// f[j][k]=f[j-1][k-a[i]+b[i]]+a[i]+b[i];
//// pre[j][k]=i;
// pre[j][k]=pre[j-1][k-a[i]+b[i]];
// pre[j][k].push_back(i);
// }
if(f[j][k] >= )
{
if(f[j+][k+a[i]-b[i]]<=f[j][k]+a[i]+b[i])
{
f[j+][k+a[i]-b[i]]=f[j][k]+a[i]+b[i] ;
pre[j+][k+a[i]-b[i]]=pre[j][k];
pre[j+][k+a[i]-b[i]].push_back(i);
}
}
}
int mk;
// for(int k=fix;k<=2*fix;k++)
// if(f[m][k]>0)
// {
// mk=k;break;
// }
// for(int k=fix;k>=0;k--)
// {
// if(fix-k>=mk-fix)break;
// if(f[m][k]>0)
// {
// mk=k;break;
// }
// }
int j=;
while(f[m][fix-j]<&&f[m][fix+j]<)j++;
if(f[m][fix-j]>f[m][fix+j])mk=fix-j;
else mk=fix+j;
int d=(f[m][mk]+(mk-fix))/;
int p=(f[m][mk]-(mk-fix))/;
// int tmp=mk;
// for(int j=m;j>0;j--)
// {
// int pr=pre[j][tmp];
// ans[j]=pr;
// tmp-=(a[pr]-b[pr]);
// }
// sort(ans+1,ans+m+1);
printf("Jury #%d\nBest jury has value %d for prosecution and value %d for defence:\n",t,d,p);
for(int i=;i<m;i++)
printf(" %d",pre[m][mk][i]);
printf("\n\n");
}
}

poj1015陪审团——DP+路径记录的更多相关文章

  1. POJ1015陪审团(Jury Compromise)——dp+路径记录

    题目:http://poj.org/problem?id=1015 差值是有后效性的,所以“转化为可行性”,开一维记录“能否达到这个差值”. 当然可以开两维分别记录 a 和 b,但 “值只是0或1” ...

  2. [IOI1999]花店橱窗布置(DP路径记录)

    题目:[IOI1999]花店橱窗布置 问题编号:496 题目描述 某花店现有F束花,每一束花的品种都不一样,同时至少有同样数量的花瓶,被按顺序摆成一行,花瓶的位置是固定的,从左到右按1到V顺序编号,V ...

  3. POJ1015 && UVA - 323 ~Jury Compromise(dp路径)

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

  4. DP+路径 URAL 1029 Ministry

    题目传送门 /* 题意:就是从上到下,找到最短路,输出路径 DP+路径:状态转移方程:dp[i][j] = min (dp[i-1][j], dp[i][j-1], dp[i][j+1]) + a[[ ...

  5. Charlie's Change_完全背包&&路径记录

    Description Charlie is a driver of Advanced Cargo Movement, Ltd. Charlie drives a lot and so he ofte ...

  6. poj--3984--迷宫问题(bfs+路径记录)

    迷宫问题 Time Limit: 1000MS   Memory Limit: 65536KB   64bit IO Format: %I64d & %I64u Submit Status D ...

  7. ros机器人之小乌龟仿真-路径记录

    ------------恢复内容开始------------ 通过自己不断地摸索,对ros系统有了一定的了解,首先装系统,这一过程中也遇到了很多问题,但通过不断地尝试,经过一天一夜的倒腾,总算是把系统 ...

  8. Codeforces Round #598 (Div. 3)E(dp路径转移)

    题:https://codeforces.com/contest/1256/problem/E 题意:给一些值,代表队员的能力值,每组要分3个或3个以上的人,然后有个评价值x=(队里最大值-最小值), ...

  9. Android中的路径记录

    Android中的路径记录 | RobinBlog 导航 导航 博客 分类 标签 友链 关于 搜索 Environment.getDataDirectory().getPath()=/dataEnvi ...

随机推荐

  1. Java生成PDF之iTextPDF的使用

    今天做财务方面相关数据的导出功能,需要导出PDF和Excel,在项目经理那里得知有一个叫iTextPDF的java框架导出PDF文件很好用,于是拿来玩儿玩儿. package com.smart.pr ...

  2. Python3.x:定时任务实现方式

    Python3.x:定时任务实现方式 Python3.x下实现定时任务的方式有很多种方式. 一.循环sleep: 最简单的方式,在循环里放入要执行的任务,然后sleep一段时间再执行.缺点是,不容易控 ...

  3. LightOJ 1030 Discovering Gold (期望)

    https://vjudge.net/problem/LightOJ-1030 题意: 在一个1×N的格子里,每个格子都有相应的金币数,走到相应格子的话,就会得到该格子的金币. 现在从1格子开始,每次 ...

  4. UVa 11270 铺放骨牌(轮廓线DP)

    https://vjudge.net/problem/UVA-11270 题意: 用1×2骨牌覆盖n×m棋牌,有多少种方法? 思路: 这道题目是典型的轮廓线DP题. 所谓轮廓线DP,就是以整行整列为状 ...

  5. 利用HTML中map标签实现整张图片带有可点击区域的图像映射:

    实现效果说明:一整张背景图片,实现图标区域出现链接,可点击跳转到指定页面. <div class="brand"> <img src="images/b ...

  6. R语言笔记-set.seed()函数

    今天查了一下R语言中set.seed(),该命令的作用是设定生成随机数的种子,种子是为了让结果具有重复性.如果不设定种子,生成的随机数无法重现. set.seed()用于设定随机数种子,一个特定的种子 ...

  7. Qt5_vs2013_error_C2001: 常量中有换行符__ZC

    ZC: 这里是解决 Windows平台下的这个 编译error :“error C2001: 常量中有换行符”. ZC: 我现在(20161221)的处理方式:vs2010或vs2015 将cpp文件 ...

  8. mybatis----Integer = 0 刷选不出来条件原因以及sql改法

    Xml写法: POJO: 当status的值为 0时该where SQLand status = 0并未正常拼接,也就是说test内的表达式为false,从而导致查询结果错误.但是,显然该值(Inte ...

  9. 身份证&银行卡识别方案

    一.  调用第三方服务 腾讯云OCR识别: 实现方法:Post图片 URL到腾讯云服务器.Post图片文件 到腾讯云服务器 b.    报价: 月接口调用总量 0<调用量≤1000 1000&l ...

  10. java生成doc和jar

    生成doc帮助文档. 第一步,需要有一个java类,里面封装了各种方法 第二部,给类和方法添加注释文档 注释文档格式: /** * */ @author 作者 @version 版本 @return ...