H - Bone Collector
H - Bone Collector
| Many years ago , in Teddy’s hometown there was a man who was called “Bone Collector”. This man like to collect varies of bones , such as dog’s , cow’s , also he went to the grave … | 
| The bone collector had a big bag with a volume of V ,and along his trip of collecting there are a lot of bones , obviously , different bone has different value and different volume, now given the each bone’s value along his trip , can you calculate out the maximum of the total value the bone collector can get ? | 
| Input The first line contain a integer T , the number of cases. Followed by T cases , each case three lines , the first line contain two integer N , V, (N <= 1000 , V <= 1000 )representing the number of bones and the volume of his bag. And the second line contain N integers representing the value of each bone. The third line contain N integers representing the volume of each bone. Output One integer per line representing the maximum of the total value (this number will be less than 2 31). | 
Sample Input
1
5 10
1 2 3 4 5
5 4 3 2 1
Sample Output
14
思路如下:
这题是一个标准的01背包问题,我们需要理解01背包的状态转移方程。
题解如下
#include<iostream>
#include<cstring>
#include<algorithm>
using namespace std;
const int Len = 1005;
int dp[Len];
int v[Len],w[Len];	//v物品所占的空间,w品的价值
int main()
{
    int t;
    cin>>t;
    while(t --)
    {
        int n,m;
        cin>>n>>m;
        for(int i = 0;i < n;i ++)
            cin>>w[i];
        for(int i = 0;i < n;i ++)
            cin>>v[i];
        memset(dp,0,sizeof(dp));
        for(int i = 0;i < n;i ++)
            for(int j = m;j >= v[i];j --)
                dp[j] = max(dp[j],dp[j - v[i]] + w[i]);
        cout<<dp[m]<<endl;
    }
    return 0;
}
H - Bone Collector的更多相关文章
- HDU 2602 Bone Collector (简单01背包)
		Bone Collector http://acm.hdu.edu.cn/showproblem.php?pid=2602 Problem Description Many years ago , i ... 
- hdu 2639 Bone Collector II
		Bone Collector II Time Limit: 5000/2000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others ... 
- Bone Collector(01背包+记忆化搜索)
		Bone Collector Time Limit : 2000/1000ms (Java/Other) Memory Limit : 32768/32768K (Java/Other) Tota ... 
- HDU2602 Bone Collector 【01背包】
		Bone Collector Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) T ... 
- HDU 2639 Bone Collector II(01背包变形【第K大最优解】)
		Bone Collector II Time Limit: 5000/2000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others ... 
- HDU 2602 Bone Collector(01背包裸题)
		Bone Collector Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) T ... 
- ACM Bone Collector
		Many years ago , in Teddy's hometown there was a man who was called "Bone Collector". Th ... 
- Hdoj 2602.Bone Collector  题解
		Problem Description Many years ago , in Teddy's hometown there was a man who was called "Bone C ... 
- hdu2602 Bone Collector 01背包
		Many years ago , in Teddy’s hometown there was a man who was called “Bone Collector”. This man like ... 
随机推荐
- Mac结合Docker开发
			Mac结合Docker开发 前几天在看Java并发实战时,在Mac上写了一个示例,结果运行后无法按照书本上运行.主要是有些命令,在Mac和Linux是有区别的,比如top, Mac上是不支持-Hp,意 ... 
- 《深入理解 Java 虚拟机》读书笔记:虚拟机类加载机制
			正文 虚拟机把描述类的数据从 Class 文件加载到内存,并对数据进行校验.转换解析和初始化,最终形成可以被虚拟机直接使用的 Java 类型,这就是虚拟机的类加载机制. 一.类加载的时机 1.类的生命 ... 
- python-面向对象小结
			面向对象 小结 1:面向对象:就是一种编程思想 简称oop,指挥某某完成能完成的功能 2:面向对象与面向过程的优缺点 : 面向过程: 优点: 复杂问题简答化(一步一步解决), 流程化, 缺点:机械化 ... 
- 调用系统的loading界面
			//在状态栏显示一个圈圈转动 代表正在请求 [UIApplication sharedApplication].networkActivityIndicatorVisible = YES; 
- js中(event)事件对象
			事件对象 • 什么是事件对象? • 就是当你触发了一个事件以后,对该事件的一些描述信息 • 例如: ° 你触发一个点击事件的时候,你点在哪个位置了,坐标是多少 ° 你触发一个键盘事件的时候,你按的是哪 ... 
- Asp.NET MvC EF实现分页
			打开Visual Studio 2017 选择 项目----->管理nuget包 其他版本也有 输入paged 下载安装 pagedList和pagedList.mvc 在model文件新建一 ... 
- BrowserSync(前端利器—保存代码后,自动刷新浏览器)
			摘要 Browsersync能让浏览器实时.快速响应您的文件更改(HTML.JavaScript.CSS.Sass.Less.PHP.Python等)并自动刷新页面.更重要的是 Browsersync ... 
- frida(hook工具)的环境搭建
			一.简介 frida 是一款基于 python+javascript 的 hook 框架,可运行在 android.ios.linux.win等各个平台,主要使用的动态二进制插桩技术. Frida官网 ... 
- js Array方法总结
			修改器方法(9) copyWithin(target: number, start: number, end?: number): this; // 浅复制数组的一部分到同一数组中的另一个位置,并返回 ... 
- 判断 tableZen 是否有 横向滚动条
			判断 tableZen 是否有 横向滚动条 const outWidth = this.$refs.tableInnerZen.$el.clientWidth ].$el.clientWidth 
