题目链接:https://vjudge.net/contest/103424#problem/A

题目大意:

第一行输入几组数据,第二行第一个数字代表物体个数,第二个数代表总体积。需要注意的是,第三排输入的是物品的价值,第四排的物品的体积。在不可以拆分物体的前提下,已知背包的总体积,最大能获取的价值是多少。

01背包模板题,没什么好说的。(附两种形式的dp数组解决方案)

//一维dp数组实现(滚动数组)
#include <iostream>
#include <cstdio>
#include <cstring>
using namespace std;
#define max(a,b) ((a)>(b)?(a):(b)) int main()
{
int t, n, m, i, j;
int a[], b[];
scanf("%d", &t);
while (t--)
{
scanf("%d%d", &n, &m);
for (i = ; i<n; i++)
scanf("%d", &a[i]);
for (i = ; i<n; i++)
scanf("%d", &b[i]);
int dp[]; //dp数组始终记录当前体积的最大价值
memset(dp, , sizeof(dp));
for (i = ; i<n; i++) //从第一个开始循环
for (j = m; j >= b[i]; j--)
dp[j] = max(dp[j], dp[j - b[i]] + a[i]); //比较放入i物体后的价值与不放之前的价值,记录大的值
printf("%d\n", dp[m]); //输入总体积的最大价值
}
return ;
}
//二维dp数组实现
#include<iostream>
using namespace std;
int dp[][]; //dp[i][j]表示前i个物品,当背包容量为j的时候所能装下大的最大值
#define max(a,b) ((a)>(b)?(a):(b)) int main()
{
int t, n, v, i, j;
int va[], vo[];
cin >> t;
while (t--)
{
cin >> n >> v;
for (i = ; i <= n; i++)
cin >> va[i];
for (i = ; i <= n; i++)
cin >> vo[i];
memset(dp, , sizeof(dp));//初始化操作
for (i = ; i <= n; i++)
{
for (j = ; j <= v; j++)
{
if (vo[i] <= j)//表示第i个物品将放入大小为j的背包中
dp[i][j] = max(dp[i - ][j], dp[i - ][j - vo[i]] + va[i]); //比较放入i物体后的价值与不放之前的价值,记录大的价值
else //第i个物品无法放入
dp[i][j] = dp[i - ][j];
}
}
cout << dp[n][v] << endl;
}
return ;
}

2018-04-27

HDU 2602 Bone Collector 骨头收集者【01背包】的更多相关文章

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

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

  2. HDOJ(HDU).2602 Bone Collector (DP 01背包)

    HDOJ(HDU).2602 Bone Collector (DP 01背包) 题意分析 01背包的裸题 #include <iostream> #include <cstdio&g ...

  3. HDU 2602 Bone Collector 0/1背包

    题目链接:pid=2602">HDU 2602 Bone Collector Bone Collector Time Limit: 2000/1000 MS (Java/Others) ...

  4. hdu 2602 Bone Collector(01背包)模板

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2602 Bone Collector Time Limit: 2000/1000 MS (Java/Ot ...

  5. HDU 2602 Bone Collector(经典01背包问题)

    题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=2602 Bone Collector Time Limit: 2000/1000 MS (Java/O ...

  6. HDU 2602 Bone Collector

    http://acm.hdu.edu.cn/showproblem.php?pid=2602 Bone Collector Time Limit: 2000/1000 MS (Java/Others) ...

  7. HDU 2602 Bone Collector (01背包问题)

    原题代号:HDU 2602 原题链接:http://acm.hdu.edu.cn/showproblem.php?pid=2602 原题描述: Problem Description Many yea ...

  8. HDU 2602 - Bone Collector - [01背包模板题]

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2602 Many years ago , in Teddy’s hometown there was a ...

  9. HDU 2602 Bone Collector(01背包裸题)

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

随机推荐

  1. pycharm永久激活(转)

    机器上安装的pycharm失效了,注册服务器也不管用了.网上找了一个比较满意的激活方法,推荐给大家: 第一步:下载jar包: 此jar包的目的就是让截获截止时间并骗过pycharm; 百度云下载地址  ...

  2. 代码控制打电话、发短信、发邮件、打开手机app等操作

    很多时候我们需要利用我门自己的app进行一些打电话.发短信等的操作,那么如何利用代码实现呢,下面就介绍一些简单的方法来实现这些操作. 一.打电话: <1>最简单.最直接的方法----直接跳 ...

  3. R-CNN论文详解(转载)

    这几天在看<Rich feature hierarchies for accurate object detection and semantic segmentation >,觉得作者的 ...

  4. C语言函数调用栈(一)

    程序的执行过程可看作连续的函数调用.当一个函数执行完毕时,程序要回到调用指令的下一条指令(紧接call指令)处继续执行.函数调用过程通常使用堆栈实现,每个用户态进程对应一个调用栈结构(call sta ...

  5. C++:greater<int>和less<int>

    greater和less是xfunctional.h中的两个结构体,代码如下: template<class _Ty = void> struct less { // functor fo ...

  6. pl sql 记住用户名密码

    tools--Preferences--Logon History 选择  “Store history”是默认勾选的,勾上“Store with password” 登录时从下拉框选择用户名则自动登 ...

  7. SonarQube代码质量管理工具安装与使用(sonarqube5.1.2 + sonar-runner-dist-2.4 + MySQL5.x)

    1. SonarQube安装(sonarqube5.1.2 + sonar-runner-dist-2.4) 1.1 前提条件 1) 已安装Java环境(version:1.7+) 2) 已安装MyS ...

  8. Oracle 高级排序函数 和 高级分组函数

    高级排序函数: [ ROW_NUMBER()| RANK() | DENSE_RANK ] OVER (partition by xx order by xx) 1.row_number() 连续且递 ...

  9. 【mysql】autocommit=0后,commit, rollback无效

    之前在[mysql]MySQLdb中的事务处理中用autocommit和commit()以及rollback()实现了事务处理. 但后来,用同样的代码在另一个数据库中运行却失败了.找了一个下午的原因. ...

  10. 事件方法on()

    on()方法用来处理事件.jQuery会处理所有浏览器的兼容性问题. on()方法可以指定影响哪个事件,相当于JavaScript中的addEventListener()事件监听. on()方法有两个 ...