前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >POJ2392 SpaceElevator [DP]

POJ2392 SpaceElevator [DP]

作者头像
全栈程序员站长
发布2022-07-07 21:04:54
910
发布2022-07-07 21:04:54
举报

大家好,又见面了,我是全栈君。

题目大意:有一头奶牛要上太空,他有非常多种石头,每种石头的高度是hi,可是不能放到ai之上的高度。而且这样的石头有ci个 将这些石头叠加起来。问可以达到的最高高度。 解题思路:首先对数据进行升序排序。这样才是一个标准的多重背包的问题 为什么要排序? 由于仅仅有这样才干得到最优解,假设一開始就是高的在前面,那么后面有低的却不能选到,就直接选高的去了。这样是不能达到最优解的 使f[i]的状态标记。能否够达到这个高度 这样可以达到取f[i]中i的最大值就可以。

这里要注意max赋初值的时候要赋值为0。不能为-1。由于答案有可能为0

代码语言:javascript
复制
#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;
}

发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/116214.html原文链接:https://javaforall.cn

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2022年1月2,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档