hdu 1069 Monkey and Banana 经典dp

 题意:给n个 维度为(x,y,z)的 立方体,垒起来,要求下层长宽严格大于上层,求最大高度

解:一个长方体理论上有6种方法,n最大30,30*6数据较小。有些特殊情况不做处理。

dp[i] 表示使用第 i 个长方体的最大高度。宽相同按照长从小到大排序,否则按照宽从小到大排序。

最后遍历取最大值

#include <iostream>
#include <vector>
#include <algorithm>
using namespace std;
struct No{
	int x,y,z;
}no[200];
int cnt = 0;
int dp[200];
void add(int x,int y,int z){
	no[cnt].x = x;	no[cnt].y = y;
	no[cnt++].z = z;
}
int cmp(No a,No b){
	if(a.x==b.x)return a.y<b.y;
	return a.x<b.x;
}
int main()
{
	int n,x,y,z,maxh,num=0;
	while(scanf("%d",&n)&&n){
		cnt = 0;
		for(int i=0;i<n;i++){
			scanf("%d %d %d",&x,&y,&z);
			add(x,y,z); add(x,z,y);
			add(z,x,y); add(z,y,x);
			add(y,x,z); add(y,z,x);
		}
		sort(no,no+cnt,cmp); 
		for(int i=0;i<cnt;i++){
			maxh = 0;
			for(int j=0;j<i;j++){
				if(no[i].x>no[j].x&&no[i].y>no[j].y)
				maxh=maxh>dp[j]?maxh:dp[j];	
			}
			dp[i]=no[i].z+maxh;
		}	
		int ans = 0;		
		for(int i=0;i<cnt;i++)
			ans=max(ans,dp[i]);
		printf("Case %d: maximum height = %d\n",++num,ans);
	}
	return 0;
}

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

wym_king

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值