传送门:http://poj.org/problem?id=3628

题目看了老半天,牛来叠罗汉- -|||和书架什么关系啊。。

大意是:一群牛来叠罗汉,求超过书架的最小高度。

0-1背包的问题,对于第i只牛可以放或者不放。然后最后求出大于书架高度的,减去书架高度即可。

也可以倒着来看。背包的容量为牛总的高度-书架的高度,求不超过这个容量的最大值,最后容量-这个值就是答案了。(推荐)

还可以DFS..

#include<cstdio>
#include<cstring>
#include<algorithm>
using namespace std;
const int MAXN=1000000+5;
int H[22],f[MAXN];
int main()
{
int N,B;
while(~scanf("%d%d",&N,&B))
{
memset(f,0,sizeof(f));
int sum=0;
for(int i=1;i<=N;i++)
{
scanf("%d",&H[i]);
sum+=H[i];
} for(int i=1;i<=N;i++)
{
for(int j=sum;j>=H[i];j--)
{
f[j]=max( f[j] , f[j-H[i]]+H[i] );
}
} for(int i=B;i<=sum;i++)
if(f[i]==i)
{
printf("%d\n",f[i]-B);
break;
} }
}
#include<cstdio>
#include<cstring>
#include<algorithm>
using namespace std;
const int MAXN=1000000+5;
int H[22],f[MAXN];
int main()
{
int N,B;
while(~scanf("%d%d",&N,&B))
{
memset(f,0,sizeof(f));
int sum=0;
for(int i=1;i<=N;i++)
{
scanf("%d",&H[i]);
sum+=H[i];
} int contain=sum-B; for(int i=1;i<=N;i++)
{
for(int j=contain;j>=H[i];j--)
{
f[j]=max( f[j] , f[j-H[i]]+H[i] );
}
} printf("%d\n",contain-f[contain]); }
}

DFS:

#include<cstdio>
#include<cstring>
#include<algorithm>
using namespace std;
const int INF=9999999;
int H[22];
bool visit[22]={0};
int N,B;
int ans;
void dfs(int cur , int sum)
{
if(sum >=ans)
return; if(cur==N)
{
if(sum>=B)
ans=sum;
return;
} dfs(cur+1,sum);
dfs(cur+1,sum+H[cur]);
}
int main()
{ while(~scanf("%d%d",&N,&B))
{
ans=INF;
for(int i=0;i<N;i++)
scanf("%d",&H[i]); dfs(0,0);
printf("%d\n",ans-B); }
}

POJ 3628 Bookshelf 2 0-1背包的更多相关文章

  1. POJ 3628 Bookshelf 2(01背包)

    Bookshelf 2 Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 9488   Accepted: 4311 Descr ...

  2. POJ 3628 Bookshelf 2【01背包】

    题意:给出n头牛的身高,以及一个书架的高度,问怎样选取牛,使得它们的高的和超过书架的高度最小. 将背包容量转化为所有牛的身高之和,就可以用01背包来做=== #include<iostream& ...

  3. poj 3628 Bookshelf 2 基本01背包

    题目大意:FJ有n头奶牛,和一个高为h的架子,给出每头奶牛高度,求使奶牛叠加起来超过架子的最低高度是多少. 题目思路:求出奶牛叠加能达到的所有高度,并用dp[]保存,最后进行遍历,找出与h差最小的dp ...

  4. POJ 3628 Bookshelf 2 (01背包)

    Bookshelf 2 Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 7496   Accepted: 3451 Descr ...

  5. POJ 3628 Bookshelf 2【背包型DFS/选or不选】

    Bookshelf 2 Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 11105   Accepted: 4928 Desc ...

  6. poj 3628 Bookshelf 2

    http://poj.org/problem?id=3628 01背包 #include <cstdio> #include <iostream> #include <c ...

  7. POJ 3628 Bookshelf 2 题解

    本题解法非常多,由于给出的数据特殊性故此能够使用DFS和BFS,也能够使用01背包DP思想来解. 由于一般大家都使用DFS,这里使用非常少人使用的BFS.缺点是比DFS更加耗内存,只是长处是速度比DF ...

  8. poj 1837 Balance (0 1 背包)

    Balance Time Limit: 1000MS   Memory Limit: 30000K Total Submissions: 10326   Accepted: 6393 题意:给你n个挂 ...

  9. POJ 1636 Prison rearrangement DFS+0/1背包

    题目链接: id=1636">POJ 1636 Prison rearrangement Prison rearrangement Time Limit: 3000MS   Memor ...

随机推荐

  1. Fragment-两种使用方式

    这篇我们就用实例来看看我们在代码中如何使用Fragment 一:静态添加Fragment 新建一个项目,添加两个Fragment的布局文件fragment_title,fragment_content ...

  2. CSU 1046 追杀

    Description 在一个8行9列的国际象棋棋盘上,有一名骑士在追杀对方的国王.该骑士每秒跨越一个2*3的区域,如下图所示. 而对方的国王慌忙落逃,他先沿着右下斜线方向一直跑,遇到边界以后会沿着光 ...

  3. uname 命令

    uname -p 显示系统的芯片类型.如,PowerPC uname -r 显示操作系统的版本号 uname -s 显示系统名称.例如,AIX uname -n 显示节点名称 uname -a 显示系 ...

  4. C/C++(语句,数组)

    C语言语句: 两大选择,三大循环,四大跳转 两大跳转:if,switch 三大循环:for,while,do-while 四大跳转:break,continue,goto,return do-whil ...

  5. 2017国家集训队作业[agc006f]Blackout

    2017国家集训队作业[agc006f]Blackout 题意: 有一个\(N*N\)的网格,一开始有\(M\)个格子被涂黑,给出这\(M\)个格子,和染色操作:如果有坐标为\((x,y),(y,z) ...

  6. mktemp---创建暂存文件

  7. 【OC学习-8】存取器方法?getter和setter?事实上就是赋值和返回值的两种函数

    我们在声明类的时候,有实例变量+方法(函数),这些实例变量假设默认的话都是protected类型,一般无法直接訪问.更别提赋值和调用了,所以就产生了两种函数,getter函数就是可以返回实例变量的值, ...

  8. Java IO:SocketChannel和Selector在ZooKeeper中应用

    转载请注明出处:jiq•钦's technical Blog 假设不了解SocketChannel和Selector.请先阅读我的还有一篇博文:点击打开链接 ZooKeeper的启动从QuorumPe ...

  9. InstallShield详细制作说明(四)

    十.编译打包

  10. 父子margin塌陷

    1.使用padding 2.给父级使用border 3.给父级添加属性 overflow:hidden 4.浮动 5.定位{absolute,fixed} 6.伪元素代码 .parent:before ...