题目地址:点击打开链接
思路:先把x排序,只能对x,y种一个变量排序,且必须对一个变量先排序,然后再保证x,y都符合要求的情况下,对高度进行DP,虽然题目说每种砖块可以无限用,但每种砖块最多只能用6次,因为每种砖块有6种摆放方法,并且摆放时要求长和宽严格递减
AC代码:
#include <iostream>
#include<algorithm>
#include<cstring>
#include<cstdio>
using namespace std;
struct blocks
{
int x,y,z;
}kind[200];
int num,dp[200];
void init(int k,int x,int y,int z)
{
kind[k].x = x;
kind[k].y = y;
kind[k].z = z;
//dp[k] = z;要排序完再赋值,不然排序完的kind值和dp值不对应
}
bool cmp(blocks a,blocks b)
{
return a.x > b.x;//只能排一个,因为虽然x很大,y很小会被排到第一个,不符合题意
}
int main()
{
int i,j,n,num,l=1;
int x,y,z,max,max1;
while(cin>>n && n)
{
num = 0;
memset(dp,0,sizeof(dp));
for(i=0; i<n; i++)
{
cin>>x>>y>>z;
init(num++,x,y,z);
init(num++,y,x,z);
init(num++,y,z,x);
init(num++,z,y,x);
init(num++,x,z,y);
init(num++,z,x,y);
}
max1 = dp[0];
sort(kind,kind+num,cmp);
for(i=0; i<num; i++)
{
dp[i] = kind[i].z;
}
for(i=1; i<num; i++)
{
max = 0;
for(j=0; j<i; j++)
{
if(kind[i].y < kind[j].y && kind[i].x < kind[j].x && dp[j]> max)//排序完的结果还有等于的情况,再判断一次
max = dp[j];
}
dp[i] += max;
if(dp[i] > max1)
max1 = dp[i];
}
printf("Case %d: maximum height = %d\n",l++,max1);//记得加\n
}
return 0;
}