hdu 5616 Jam's balance 正反背包+转换
http://acm.hdu.edu.cn/showproblem.php?pid=5616
思路
题目中蕴含着两种需要计算的重量
1. 从所有的砝码中挑出任意种
2.(转换的思想)在天平的两端都挑出这些砝码中的一些,它也可以计算出差值,这个差值也是一种重量
这其实一种转换,看下面这个公式(左端砝码的重量)==(右端砝码的重量+能计算出的重量G)
当第一次选择一个砝码,我们计算出了以第二种方式的一种重量G,那么它也要被记为true,它还可以
继续更新出新的重量,G(新的左端砝码重量)=(右端砝码的重量+能计算出的重量)
那么上述的过程就是一个从背包里取出东西的过程。
在代码里有详细的分析。
背包正反各来一遍
代码:
#include<iostream>
#include<cstdio>
#include<cstring>
#include<cmath>
#include<algorithm>
#define MAXN 2005
using namespace std;
int w[MAXN];
bool dp[MAXN];//滚动数组,只要一维,内存优化
int main()
{
int t,n,q,k;
scanf("%d",&t);
while(t--)
{
scanf("%d",&n);
for(int i = ;i<n;i++)
{
scanf("%d",&w[i]);
}
memset(dp,false,sizeof(dp));
dp[] = true;
//positive
//正着来一次背包,按阶段每一次添加一个
for(int i = ;i<n;i++)
{
//每一次选择当前这个砝码,j表示的是当前可以称出来的重量
//j-w[i]表示前一轮该重量是否有
for(int j = MAXN;j>=w[i];j--)
{
dp[j]|=dp[j-w[i]];
} //必须倒着来,如果正着来错误!!
/*
for(int j = 0;j<=MAXN-w[i];j++)
{
dp[j+w[i]]|=dp[j];
}
在这一次循环中用到了本轮已更新的结果,我们只能用前一轮的结果
这样会出现的错误是一轮中加了n个w[i],而且在本轮中加了n个,毫无疑问!
*/
} //negative
//逆着来一遍,从背包中取出东西
for(int i = ;i<n;i++)
{
//按照我的题解就是每一次选中当前的这个砝码作为右端砝码
//j表示左端减去右端的重量
//也许你要理解的是每一次你只选一个,这样的话要是右端放多个不也行吗
//但是你要知道你每一轮的新重量其实是保留下来了(更新了)
//所以下一轮中用了前一个砝码的新重量你还可以用(也就是再减一个砝码)
for(int j = ; j<=MAXN-w[i] ; j++)
{
dp[j]|=dp[j+w[i]];
} //必须正着来,如果倒着来也错误!!
/*
for(int j = MAXN-w[i];j>=0;j--)
{
dp[j-w[i]]|=dp[j];
}
在这一次循环中用到了本轮已更新的结果,我们只能用前一轮的结果
这样会出现的错误是一轮中减了n个w[i],而且在本轮中减了n个,毫无疑问!
*/
}
scanf("%d",&q);
for(int i = ;i<=q;i++)
{
scanf("%d",&k);
if(dp[k])
printf("YES\n");
else
printf("NO\n");
}
}
return ;
}
hdu 5616 Jam's balance 正反背包+转换的更多相关文章
- HDU 5616 Jam's balance(01背包)
题目网址:http://acm.hdu.edu.cn/showproblem.php?pid=5616 题目: Jam's balance Time Limit: 2000/1000 MS (Java ...
- HDU 5616 Jam's balance(Jam的天平)
HDU 5616 Jam's balance(Jam的天平) Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/65536 K ...
- HDU 5616 Jam's balance 背包DP
Jam's balance Problem Description Jim has a balance and N weights. (1≤N≤20)The balance can only tell ...
- HDU 5616 Jam's balance(DP)
题目网址:http://acm.hdu.edu.cn/showproblem.php?pid=5616 题目: Jam's balance Time Limit: 2000/1000 MS (Java ...
- hdu 5616 Jam's balance(dp 正反01背包)
来自官方题解: AC代码: #pragma comment(linker, "/STACK:1024000000,1024000000") #include<iostream ...
- HDU 5616 Jam's balance
背包.dp[i]=1表示i这种差值能被组合出来,差值有负数,所以用sum表示0,0表示-sum,2*sum表示sum. 询问X的时候,只需看dp[sum+X]或者dp[sum-X]是否有一个为1,注意 ...
- HDU 5616:Jam's balance(背包DP)
http://acm.hdu.edu.cn/showproblem.php?pid=5616 题意:有n个物品,每个重量为w[i],有一个天平,你可以把物品放在天平的左边或者右边,接下来m个询问,问是 ...
- HDU 5234 Happy birthday --- 三维01背包
HDU 5234 题目大意:给定n,m,k,以及n*m(n行m列)个数,k为背包容量,从(1,1)开始只能往下走或往右走,求到达(m,n)时能获得的最大价值 解题思路:dp[i][j][k]表示在位置 ...
- cdq分治(hdu 5618 Jam's problem again[陌上花开]、CQOI 2011 动态逆序对、hdu 4742 Pinball Game、hdu 4456 Crowd、[HEOI2016/TJOI2016]序列、[NOI2007]货币兑换 )
hdu 5618 Jam's problem again #include <bits/stdc++.h> #define MAXN 100010 using namespace std; ...
随机推荐
- C++学习笔记30,指针的引用(2)
版权声明:本文为博主原创文章,未经博主同意不得转载. https://blog.csdn.net/guang_jing/article/details/32910093 能够创建不论什么类型的引用,包 ...
- 如何写PHP规范注释
所有的文档标记都是在每一行的 * 后面以@开头.如果在一段话的中间出来@的标记,这个标记将会被当做普通内容而被忽略掉. @access 该标记用于指明关键字的存取权限:private.p ...
- IOS int NSInteger NSNumber区分
1.NSNumber 是一个类继承于NSValue 即一个基本数据类型的集合 包括char a signed or unsigned char, short int, int, long int, l ...
- 0522 HTML表单 CSS基础
一.列表标签 列表标签分为三种. 1.无序列表<ul>,无序列表中的每一项是<li> 英文单词解释如下: ul:unordered list,“无序列表”的意思. li:lis ...
- linux下扩展root分区
1 查看当前磁盘情况 fdisk -l /dev/sda1 2048 6143 2048 83 Linux /dev/sda2 * 6144 1054719 524288 83 Linux /dev/ ...
- Eclipse快捷键与Notepad++ 快捷建冲突的问题
notepad++添加了zen coding插件以后,notepad++默认的快捷键中Alt+/也是其快捷键中的一个,表示toggle comment,而用myeclipce或eclipse的朋友都知 ...
- tomcat7 中的坑。 关于welcome-list和servlet-mapping
web.xml中, 使用default servlet设置了针对静态资源后缀名的过滤. 并且设置了welcome-list, 使用jetty和tomcat6启动一切正常, 但是使用tomcat7则出现 ...
- spring学习(5)
bean配置 启用注解 <context:annotation-config/> 使用spring的特殊bean 对bean BeanPostProcessor spring本身提供的特殊 ...
- Java的TCP网络编程
服务端代码: package socket; import java.io.BufferedReader; import java.io.IOException; import java.io.Inp ...
- mysql的SQL_CALC_FOUND_ROWS 使用 类似count(*) 使用性能更高
mysql的SQL_CALC_FOUND_ROWS 使用 类似count(*) 使用性能更高 在很多分页的程序中都这样写: SELECT COUNT(*) from `table` WHERE ... ...