题意:

01背包,找出第k最优解

题解:

对于01背包最优解我们肯定都很熟悉

第k最优解的话也就是在dp方程上加一个维度来存它的第k最优解(dp[i][j]代表,体积为i能获得的第j最大价值)

对于每一个物品只有两种选择情况

1、把这个物品加入背包

2、不要这个物品

那么它的前k种最优解也是由n种物品的这两个选择组成的

假设总体积是4,现在有两种物品,求第2最大值

1、体积1,价值3

2、体积1,价值2

最开始dp状态:

体积:    1  2  3  4

第1最大值:0  0  0  0

第2最大值:0  0  0  0

x、y数组是用来记录他从上一个状态转移过来的前k最大值。

x数组代表需要这个物品的时候的前k最大值

y数组代表不需要这个物品的时候前k最大值

下面演示过程:

体积为4的时候

x[1]=v[4-1][1]+3 =3

x[2]=v[4-1][2]+3 =3

y[1]=v[4][1]=0

y[2]=v[4][2]=0

下面那个while循环的意思就是给x数组和y数组这4个数(因为我要求第2(k)最大值,所以是2*2(2*k)个数)从大到小排序之后去重,从中挑出来2(k)个赋值给v[j][1],v[j][2](v[j][1]...v[j][k])

排序后:3 3 0 0,去重后3 0

那么v[4][1]=3,v[4][2]=0

可能有些人不明白while代码中怎么会有去重操作,我们来看一下

给v[4][1]赋值的时候因为x[1]=3>y[1]=0,所以很自然v[4][1]=3

这个时候给v[4][2]赋值,因为x[2]=3>y[1]=0,所以v[4][2]=3。但是因为v[4][1]==v[4][2]所以循环不会结束

我们来看一下循环结束条件while((m<=f || n<=f) && o<=f)

之有前k个最优值都找到之后循环会结束,或者x和y数组所有值都用完了

所以还是去给v[4][2]赋值,那么又因为x[3]=y[3]=-1。所以x[3]=-1<y[0]=0,那么v[4][2]=0

这个时候循环就结束了

我上面解释的时候用的是前k最大值,代码中用的字母是f。。。

代码:

 1 #include<stdio.h>
2 #include<string.h>
3 int q[105],w[105],v[1005][35],x[1005],y[1005];
4 int main()
5 {
6 int a,s,sum,d,f,g;
7 scanf("%d",&a);
8 while(a--)
9 {
10 memset(v,0,sizeof(v));
11 scanf("%d%d%d",&s,&d,&f);
12 for(int i=1; i<=s; ++i)
13 {
14 scanf("%d",&w[i]);
15 sum+=w[i];
16 }
17 for(int i=1; i<=s; ++i)
18 scanf("%d",&q[i]);
19 for(int i=1; i<=s; ++i)
20 {
21 for(int j=d; j>=q[i]; --j)
22 {
23 int k;
24 for(k=1; k<=f; ++k)
25 {
26 x[k]=v[j-q[i]][k]+w[i];
27 y[k]=v[j][k];
28 }
29 x[k]=y[k]=-1;
30 int m,n,o;
31 m=n=o=1;
32 while((m<=f || n<=f) && o<=f)
33 {
34 if(x[m]>y[n])
35 {
36 v[j][o]=x[m];
37 ++m;
38 }
39 else
40 {
41 v[j][o]=y[n];
42 ++n;
43 }
44 if(v[j][o]!=v[j][o-1]) ++o;
45 }
46 }
47 }
48 printf("%d\n",v[d][f]);
49 }
50 return 0;
51 }

Bone Collector II HDU - 2639 01背包第k最大值的更多相关文章

  1. HDU 2639(01背包第K大)

    http://acm.hdu.edu.cn/showproblem.php?pid=2639 http://blog.csdn.net/lulipeng_cpp/article/details/758 ...

  2. HDU 2639 01背包(分解)

    http://acm.hdu.edu.cn/showproblem.php?pid=2639 01背包第k优解,把每次的max分步列出来即可 #include<stdio.h> #incl ...

  3. HDU 2639 01背包求第k大

    Bone Collector II Time Limit: 5000/2000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others ...

  4. HDU 2602 Bone Collector骨头收藏者(01背包)

    题意:收藏骨头. 思路: 常规的01背包. #include <iostream> #define N 1005 using namespace std; int volume[N]; / ...

  5. hdoj2602 Bone Collector(DP,01背包)

    题目链接 http://acm.hdu.edu.cn/showproblem.php?pid=2602 题意 有n块骨头,每块骨头体积为volume,价值为value,还有一个容量为v的背包,现在将骨 ...

  6. HDU 2639 Bone Collector II(01背包变形【第K大最优解】)

    Bone Collector II Time Limit: 5000/2000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others ...

  7. hdu 2639 Bone Collector II(01背包 第K大价值)

    Bone Collector II Time Limit: 5000/2000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others ...

  8. HDU 2639 Bone Collector II【01背包 + 第K大价值】

    The title of this problem is familiar,isn't it?yeah,if you had took part in the "Rookie Cup&quo ...

  9. HDU 3639 Bone Collector II(01背包第K优解)

    Bone Collector II Time Limit: 5000/2000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others ...

随机推荐

  1. 【Linux】history用法

    通过history命令可以查看我们在系统中输入过的命令 history命令的一些常用参数 -c  清空内存中命令历史 -d #  删除指定的历史命令,比如 history -d 100 ,就是删除第1 ...

  2. ctfhub技能树—sql注入—过滤空格

    手注 查询数据库 -1/**/union/**/select/**/database(),2 查询表名 -1/**/union/**/select/**/group_concat(table_name ...

  3. BAPI_GOODSMVT_CREATE的参数GOODSMVT_CODE的说明

    BAPI_GOODSMVT_CREATE 的功能就是用于货物移动,其主要可以实现MB*事物的一些功能,其中该BAPI的参数 GOODSMVT_CODE就控制了对应哪个事物码的功能,下面给出该参数的值和 ...

  4. 前端面试准备笔记之JavaScript(01)

    1.1 typeof 能判断哪些类型? typeof可以识别所有的值类型 typeof可以识别函数 //function typeof可以判断是否是引用类型(不可以再细分) //object 1.2 ...

  5. 用CSS制做一个三角形!

    用CSS制做一个三角形! <style> .outer { width: 0; height: 0; border-left: 10px solid transparent; border ...

  6. 【WPF】将DataGrid内容导出到Excel

    引言 在做项目时要求将datagrid的内容导出到Excel,以前做winform项目时遇到过,就把代码搬过来用,但wpf和winform还是有些不同,就修改了一些东西,使其能实现这个功能. 本文是导 ...

  7. jackson学习之四:WRAP_ROOT_VALUE(root对象)

    欢迎访问我的GitHub https://github.com/zq2599/blog_demos 内容:所有原创文章分类汇总及配套源码,涉及Java.Docker.Kubernetes.DevOPS ...

  8. javascript之Banner图片焦点轮播

    这个Banner唯一不好的就是没有前进和后退的button,写过两个版本的banner,这次这个是下面有浮动层的. <!DOCTYPE html><html xmlns=" ...

  9. 风险识别系统-大数据智能风控管理平台-企业风控解决方案– 阿里云 https://www.aliyun.com/product/saf

    风险识别系统-大数据智能风控管理平台-企业风控解决方案– 阿里云 https://www.aliyun.com/product/saf

  10. Tensorflow-卷积神经网络CNN

    卷积神经网络CNN 结构 池化操作 手写数字-卷积神经网络实现 import tensorflow as tf from tensorflow.examples.tutorials.mnist imp ...