HDU 2602 Bone Collector 骨头收集者【01背包】
题目链接: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背包】的更多相关文章
- HDU 2602 Bone Collector骨头收藏者(01背包)
题意:收藏骨头. 思路: 常规的01背包. #include <iostream> #define N 1005 using namespace std; int volume[N]; / ...
- HDOJ(HDU).2602 Bone Collector (DP 01背包)
HDOJ(HDU).2602 Bone Collector (DP 01背包) 题意分析 01背包的裸题 #include <iostream> #include <cstdio&g ...
- HDU 2602 Bone Collector 0/1背包
题目链接:pid=2602">HDU 2602 Bone Collector Bone Collector Time Limit: 2000/1000 MS (Java/Others) ...
- hdu 2602 Bone Collector(01背包)模板
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2602 Bone Collector Time Limit: 2000/1000 MS (Java/Ot ...
- HDU 2602 Bone Collector(经典01背包问题)
题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=2602 Bone Collector Time Limit: 2000/1000 MS (Java/O ...
- HDU 2602 Bone Collector
http://acm.hdu.edu.cn/showproblem.php?pid=2602 Bone Collector Time Limit: 2000/1000 MS (Java/Others) ...
- HDU 2602 Bone Collector (01背包问题)
原题代号:HDU 2602 原题链接:http://acm.hdu.edu.cn/showproblem.php?pid=2602 原题描述: Problem Description Many yea ...
- HDU 2602 - Bone Collector - [01背包模板题]
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2602 Many years ago , in Teddy’s hometown there was a ...
- HDU 2602 Bone Collector(01背包裸题)
Bone Collector Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) T ...
随机推荐
- cetus系列~ cetus+mha
一 简介:mha+cetus高可用架构二 环境 1 mysql 5.7 并行复制+GTID 2 cetus最新版 3 mha0.57二 安装 1 安装mha-rpm包 2 做免密认证 3 ...
- FPN-Feature Pyramid Networks for Object Detection
FPN-Feature Pyramid Networks for Object Detection 标签(空格分隔): 深度学习 目标检测 这次学习的论文是FPN,是关于解决多尺度问题的一篇论文.记录 ...
- 【转】mysql8.0 在window环境下的部署与配置
[转]mysql8.0 在window环境下的部署与配置 今天在阿里云window服务器上配置mysql环境,踩了一些坑,分享出来.需要的朋友可以看看.额,或许有人要吐槽我为什么不在linux上去配置 ...
- kindle转换工具-calibre
kindle转换工具 calibre https://calibre-ebook.com/download_windows
- 八大最安全的Linux发行版,具备匿名功能,做服务器的首选,web,企业服务器等
10 best Linux distros for privacy fiends and security buffs in 2017 Introduction The awesome operati ...
- linux添加定时任务crond
1.crontab –e:编辑当前定时任务 保存完重新crond : service crond restart 2. crontab用法 crontab –e : 修改 crontab 文件,如果文 ...
- Python3学习笔记10-条件控制
Python条件语句是通过一条或多条语句的执行结果(True或者False)来决定执行的代码块 var1 = 100 if var1: print("1 - if 表达式条件为 true&q ...
- Project Euler Problem7
10001st prime Problem 7 By listing the first six prime numbers: 2, 3, 5, 7, 11, and 13, we can see t ...
- Qt5.8 在windows下mingw静态编译
官方对编译一些条件介绍:https://doc.qt.io/qt-5/windows-requirements.html 在默认情况下,用QtCreator编译程序时,使用的是动态编译.编译好的程序在 ...
- (常用)re模块
re模块(正则)#re:一些带有特殊含义的符号或者符号的组合#为什么要用re:一堆字符串中找到你所需要的内容,过滤规则是什么样,通过re模块功能来告诉计算机你的过滤规则#应用:在爬虫中最为常用:使用爬 ...