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; ...
随机推荐
- 我的Android进阶之旅------>WindowManager.LayoutParams介绍
本文转载于: http://hubingforever.blog.163.com/blog/static/171040579201175111031938/ 本文参照自: http://develop ...
- strstr使用
extern char strstr(char str1, const char *str2); 语法: strstr(str1,str2) str1: 被查找目标 string expression ...
- sprintf在51单片机中的使用
sprintf在51单片机中的使用 unsigned char ch20_str[4]; unsigned char ch2o_m_str[6]; ch2o = 123; ch2o_m = 23456 ...
- php面向对象加载类
php加载类: 新建php文件用驼峰法命名类名: 每个单词首字母大写,后面加.class.php表示这是php类文件.例如: ClubMember.class.php 若为纯php页面,<?ph ...
- pandas.resample()
http://www.cnblogs.com/hhh5460/p/5596340.html resample与groupby的区别:resample:在给定的时间单位内重取样groupby:对给定的数 ...
- js实现select动态添加option
关于 select 的添加 option 应该注意的问题. 标准的做法如上也就是说,标准的做法是 s.options.add();但是如果你一定要用 s.appendChild(option);注意了 ...
- UITableViewCell高度自适应的关键点
iOS开发中对于UITableViewCell高度自适应的文章已经很多很多,但如果cell内容比较复杂,刚使用autolayout配置自使用时还是总不能一次性成功. KEY POINT 这里只说设置的 ...
- cat echo 打印菜单
cat << END ============================= 1.apple 2.pear 3.banana ...
- 申请内存的方式(1,malloc/free;2,new/delete)
一.malloc/free的方式 // 4个int 的大小int *p = (int*) malloc(16); for (int i = 0; i < 4; ++i) { p[i] = i; ...
- An Assembly Language
BUFFER OVERFLOW 3 An Assembly Language Introduction Basic of x86 Architecture Assembly Language Comp ...