963 AlvinZH打怪刷经验(背包DP大作战R)
963 AlvinZH打怪刷经验
思路
这不是一道普通的01背包题。大家仔细观察数据的范围,可以发现如果按常理来的话,背包容量特别大,你也会TLE。
方法一:考虑01背包的一个常数优化----作用甚微。考虑到V很大时,由于只需要dp[V]的值,倒推前一个物品,只要知道dp[V-Wn]即可。以此类推,对以第j个背包,其实只需要知道到dp[V-sum{w[j..n]}]即可。这是DP无后效性的理解。
什么是01背包常数优化?
这种方法可以卡着时间点过这题,具体参考参考代码一。
方法二:动态规划需要变通!!!发现价值之和的最大值只有10^5,逆向思维,容量与价值概念互换,用最大价值来求最小容量;即,把价值之和看作是背包容量,转化为求最大价值对应的最小容量进行背包。
效率很高,不是上一种方法能比的,毕竟差了好几个数量级。具体参考参考代码二。
参考代码一
//
// Created by AlvinZH on 2017/11/16.
// Copyright (c) AlvinZH. All rights reserved.
//
#include <cstdio>
#include <iostream>
#include <cstring>
#define INF 0x3f3f3f3f
using namespace std;
int n, m, sum;
int Weight[102];//体积
int Value[102];//价值
int dp[100005];
int main()
{
while(~scanf("%d %d", &n, &m))
{
int wSum = 0, vSum = 0;
memset(dp, INF, sizeof(dp));
for (int i = 0; i < n; ++i) {
scanf("%d %d", &Weight[i], &Value[i]);
wSum += Weight[i];
vSum += Value[i];
}
dp[vSum] = wSum;
for (int i = 0; i < n; ++i) {
for (int j = Value[i]; j <= vSum; ++j) {
if(dp[j] - Weight[i] >= 0)
dp[j - Value[i]] = min(dp[j-Value[i]], dp[j]-Weight[i]);
}
}
for (int i = vSum; i >= 0; --i) {
if(dp[i] <= m) {
printf("%d\n", i);
break;
}
}
}
}
参考代码二
//
// Created by AlvinZH on 2017/11/16.
// Copyright (c) AlvinZH. All rights reserved.
//
#include <cstdio>
#include <iostream>
#include <cstring>
#define INF 0x3f3f3f3f
using namespace std;
int n, m, sum;
int Weight[102];//体积
int Value[102];//价值
int dp[100005];
int main()
{
while(~scanf("%d %d", &n, &m))
{
int wSum = 0, vSum = 0;
memset(dp, INF, sizeof(dp));
for (int i = 0; i < n; ++i) {
scanf("%d %d", &Weight[i], &Value[i]);
wSum += Weight[i];
vSum += Value[i];
}
dp[0] = 0;
dp[vSum] = wSum;
for (int i = 0; i < n; ++i) {
for (int j = vSum; j >= Value[i]; --j) {
if(dp[j] > dp[j-Value[i]] + Weight[i])
dp[j] = dp[j-Value[i]] + Weight[i];
}
}
for (int i = vSum; i >= 0; --i) {
if(dp[i] <= m) {
printf("%d\n", i);
break;
}
}
}
}
963 AlvinZH打怪刷经验(背包DP大作战R)的更多相关文章
- AlvinZH掉坑系列讲解(背包DP大作战H~M)
本文由AlvinZH所写,欢迎学习引用,如有错误或更优化方法,欢迎讨论,联系方式QQ:1329284394. 前言 动态规划(Dynamic Programming),是一个神奇的东西.DP只能意会, ...
- 976 AlvinZH想回家(背包DP大作战T)
976 AlvinZH想回家 思路 如果在第i小时有一些飞机延误,那么一架飞机的c值越大,这一小时产生的损失也越大.而使这一小时产生的损失尽可能的小并不会导致接下来时间产生的损失增大.因此应当每一小时 ...
- 977 AlvinZH过生日(背包DP大作战S)
977 AlvinZH过生日 思路 难题.逆推DP. 要明确dp的状态只与是否有选择权有关,而与选择权在谁手里无关.因为不论选择权在谁手里,那个人都会尽可能的获得最大的蛋糕重量. dp[i]表示分配到 ...
- 991 AlvinZH的奇幻猜想----整数乘积plus(背包DP大作战P)
914 AlvinZH的奇幻猜想----整数乘积puls 思路 难题.动态规划. 将数字串按字符串输入,处理起来更方便些. dp[i][j]:表示str[0~i]中插入j个乘号时的乘积最大值.状态转移 ...
- 906 AlvinZH的奇幻猜想----整数乘积(背包DP大作战O)
906 AlvinZH的奇幻猜想----整数乘积 思路 难题.动态规划. 将数字串按字符串输入,处理起来更方便些. dp[i][j]:表示str[0~i]中插入j个乘号时的乘积最大值.状态转移方程为: ...
- 851 AlvinZH的鬼畜密码(背包DP大作战N)
851 AlvinZH的鬼畜密码 思路 难题.动态规划. 先判断字符串是否合理(可翻译),然后分段处理,每一小段用动态规划求出解法数. dp[i]:字符串str[0~i]的解法数.通过判断str[i] ...
- DP大作战—组合背包
题目描述 组合背包:有的物品只可以取一次(01背包),有的物品可以取无限次(完全背包),有的物品可以取的次数有一个上限(多重背包). DD大牛的伪代码 for i = 1 to N if 第i件物品属 ...
- DP大作战——多重背包
题目描述 在之前的上机中,零崎已经出过了01背包和完全背包,也介绍了使用-1初始化容量限定背包必须装满这种小技巧,接下来的背包问题相对有些难度,可以说是01背包和完全背包的进阶问题. 多重背包:物品可 ...
- DP大作战—状态压缩dp
题目描述 阿姆斯特朗回旋加速式阿姆斯特朗炮是一种非常厉害的武器,这种武器可以毁灭自身同行同列两个单位范围内的所有其他单位(其实就是十字型),听起来比红警里面的法国巨炮可是厉害多了.现在,零崎要在地图上 ...
随机推荐
- Ext.data.association.hasMany一对多模型使用示例
来自<sencha touch权威指南>第11章,323页开始 --------------------------------------------------- index.html ...
- code1039 数的划分
来自http://blog.csdn.net/WhiStLenA/article/details/51585992 重点内容 设F(i,j)为用j个数组成i,答案为F(7,3)的话. 一个思路是,对于 ...
- 23-tcp协议——TIME_WAIT状态和FIN_WAIT2状态
23-tcp协议——TIME_WAIT状态和FIN_WAIT2状态 摘自:https://blog.csdn.net/qq_35733751/article/details/80146161 2018 ...
- hbase java api样例(版本1.3.1,新API)
hbase版本:1.3.1 目的:HBase新API的使用方法. 尝试并验证了如下几种java api的使用方法. 1.创建表 2.创建表(预分区) 3.单条插入 4.批量插入 5.批量插入(客户端缓 ...
- atom插件记录
├── Zen@0.16.4 写作的时候用,很给力 ├── atom-beautify@0.29.9 美化一切代码 ├── autocomplete-paths@1.0.2 路径自动提示 ├── au ...
- java操作ceph之rbd基本操作
一.安装librados和librbd Ceph存储集群提供了基本的存储服务,允许Ceph在一个统一的系统中唯一地传送对象,块和文件存储. 但是,不限于使用RESTful,块或POSIX接口. 基于R ...
- org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'supplierAction': Injection of resource dependencies failed; nested exception is org.springframework.beans.factor
这个错误是因为抽象Action类的时候,把ServletContext写成了serverContext,导致无法注入,正确写法是 import javax.annotation.Resource; i ...
- java上转型之instanceof--避免引用类型强制转化出错
Object obj="hello"; 上面的obj是什么类型? object?NO!String?NO? 答案:编译阶段是Object类型,而在运行阶段是String类型.实际上 ...
- 浅谈https\ssl\数字证书
全球可信的SSL数字证书申请:http://www.shuzizhengshu.com 在互联网安全通信方式上,目前用的最多的就是https配合ssl和数字证书来保证传输和认证安全了.本文追本溯源围绕 ...
- NIOS II 自定义IP核编写基本框架
关于自定义IP .接口 a.全局信号 时钟(Clk),复位(reset_n) b.avalon mm slave 地址(as_address) 片选(as_chipselect /as_chipsel ...