大家好,又见面了,我是全栈君。
将这些石头叠加起来。问可以达到的最高高度。
解题思路:首先对数据进行升序排序。这样才是一个标准的多重背包的问题
为什么要排序?
由于仅仅有这样才干得到最优解,假设一開始就是高的在前面,那么后面有低的却不能选到,就直接选高的去了。这样是不能达到最优解的
使f[i]的状态标记。能否够达到这个高度
这样可以达到取f[i]中i的最大值就可以。
这里要注意max赋初值的时候要赋值为0。不能为-1。由于答案有可能为0
#include <iostream> #include <cmath> #include <cstring> #include <cstdio> #include <cstdlib> #include <algorithm> using namespace std; int type; int f[44444],usr[44444]; struct Block { int h,a,c; }block[555]; bool cmp(Block a,Block b) { return a.a<b.a; } int main() { scanf("%d",&type); for(int i=1;i<=type;i++) { scanf("%d%d%d",&block[i].h,&block[i].a,&block[i].c); } sort(block+1,block+1+type,cmp); int maxn=0; f[0]=1; for(int t=1;t<=type;t++) { memset(usr,0,sizeof(usr)); for(int h=block[t].h;h<=block[t].a;h++) { if(!f[h] && f[h-block[t].h] && usr[h-block[t].h]+1<=block[t].c) { usr[h]=usr[h-block[t].h]+1; f[h]=1; maxn=max(h,maxn); } } } printf("%d\n",maxn); return 0; }
发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/116214.html原文链接:https://javaforall.cn
【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛
【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...