HDU 1069 monkey an banana DP LIS

Time Limit:1000MS     Memory Limit:32768KB     64bit IO Format:%I64d & %I64uDescription

一组研究人员正在设计一项实验,以测试猴子的智商。他们将挂香蕉在建筑物的屋顶,同时,提供一些砖块给这些猴子。如果猴子足够聪明,它应当能够通过合理的放置一些砖块建立一个塔,并爬上去吃他们最喜欢的香蕉。

研究人员有n种类型的砖块,每种类型的砖块都有无限个。第i块砖块的长宽高分别用xi,yi,zi来表示。 同时,由于砖块是可以旋转的,每个砖块的3条边可以组成6种不同的长宽高。

在构建塔时,当且仅当A砖块的长和宽都分别小于B砖块的长和宽时,A砖块才能放到B砖块的上面,因为必须留有一些空间让猴子来踩。

你的任务是编写一个程序,计算猴子们最高可以堆出的砖块们的高度。

Input

输入文件包含多组测试数据。

每个测试用例的第一行包含一个整数n,代表不同种类的砖块数目。n<=30.

接下来n行,每行3个数,分别表示砖块的长宽高。

当n= 0的时候,无需输出任何答案,测试结束。

Output

对于每组测试数据,输出最大高度。格式:Case 第几组数据: maximum height = 最大高度

Sample Input

1

10 20 30 

6 8 10 
5 5 5 

1 1 1 
2 2 2 
3 3 3 
4 4 4 
5 5 5 
6 6 6 
7 7 7 

31 41 59 
26 53 58 
97 93 23 
84 62 64 
33 83 27 
0

Sample Output

Case 1: maximum height = 40

Case 2: maximum height = 21 
Case 3: maximum height = 28 
Case 4: maximum height = 342

程序分析:这是一道经典的动态规划题,这个其实可以看作背包01问题来看待,背包01问题的特点是每件物品仅有一件,可以选择放或者不放,其实这道题虽然说有无限个砖块,可是他每种砖块转换成6种状态之后,每种状态只可能出现一次,因为还有长和宽的限制。那么可以得到这个问题的最优子结构,用h[i]表示以第i个砖块作为最上面一个砖块可以得到的最大距离,为了保证其最优性,状态转移方程为h[i]=max{h[j],j<i},这个方程是因为事先经过排序,使得面积从大到小排,因此序号大于i的砖块不可能放在砖块i的下面。

程序代码:

#include"iostream"
#include"cstring"
#include"algorithm"
typedef long long ll;
using namespace std;

const int maxn=180+10;

int cass=0;

struct node
{
    int x,y,z;
    void get(int x2,int y2,int z2)
    {
        x=x2;
        y=y2;
        z=z2;
    }
}a[maxn];

bool cmp(node a1,node a2)
{
    int su1=a1.x*a1.y;
    int su2=a2.x*a2.y;
    return su1>su2;
}

int n;
int k;
ll h[maxn];

bool is(node a1,node a2)
{
    if(a1.x<a2.x&&a1.y<a2.y) return true;
    return false;
}

void Init()
{
    int x1,y1,z1;
    k=1;
    a[0].x=a[0].y=10000000;
  for(int i=0;i<n;i++)
  {
      cin>>x1>>y1>>z1;
      a[k++].get(x1,y1,z1);
      a[k++].get(y1,x1,z1);
      a[k++].get(z1,y1,x1);
      a[k++].get(x1,z1,y1);
      a[k++].get(y1,z1,x1);
      a[k++].get(z1,x1,y1);
  }
  sort(a+1,a+k+1,cmp);
}

void Work()
{
    ll MAX=0;
    int i,j;
    memset(h,0,sizeof(h));
    for(i=1;i<k;i++)
    {
     for(j=0;j<i;j++)
     {
       if(is(a[i],a[j])&&a[i].z+h[j]>h[i])
       h[i]=a[i].z+h[j];
     }
     MAX=max(h[i],MAX);
    }
    cout<<"Case "<<++cass<<": maximum height = "<<MAX<<endl;
}

int main()
{
    while(cin>>n&&n)
    {
     Init();
     Work();
    }
    return 0;
}
时间: 2024-08-11 03:10:53

HDU 1069 monkey an banana DP LIS的相关文章

HDU 1069 Monkey and Banana DP LIS变形题

http://acm.hdu.edu.cn/showproblem.php?pid=1069 意思就是给定n种箱子,每种箱子都有无限个,每种箱子都是有三个参数(x, y, z)来确定. 你可以选任意两个参数作为长和宽,第三个是高. 然后要求把箱子搭起来,使得高度最高. 能搭的前提是下面那个箱子的长和宽都 > 上面那个箱子的. 思路: 因为同一个箱子可以产生6中不同的箱子,而每种最多选一个,因为相同的箱子最多只能搭起来一个. 那么可以把所有箱子都弄出来,排序,就是LIS的题目了. dp[i]表示以

HDU 1069 Monkey and Banana(DP 长方体堆放问题)

Monkey and Banana Problem Description A group of researchers are designing an experiment to test the IQ of a monkey. They will hang a banana at the roof of a building, and at the mean time, provide the monkey with some blocks. If the monkey is clever

HDU 1069 Monkey and Banana dp 题解

HDU 1069 Monkey and Banana 题解 纵有疾风起 题目大意 一堆科学家研究猩猩的智商,给他M种长方体,每种N个.然后,将一个香蕉挂在屋顶,让猩猩通过 叠长方体来够到香蕉. 现在给你M种长方体,计算,最高能堆多高.要求位于上面的长方体的长要大于(注意不是大于等于)下面长方体的长,上面长方体的宽大于下面长方体的宽. 输入输出 开始一个数n,表示有多少种木块,木块的数量无限,然后接下来的n行,每行3个数,是木块的长宽高三个参量 输出使用这些在满足条件的情况下能够摆放的最大高度 解

hdu(1069)——Monkey and Banana(LIS变形)

题意: 现在给你n个石块,然后它由坐标来表示(x,y,z).但是它可以有不同的方法,也就是说它的三个坐标可以轮换着来的. 石块的数量不限,但是每次都必须保持上底面的长和宽严格递减,然后问你用这些石块所能拼成的最大高度是多少. 思路: 因为坐标有多种情况,所以我们可以把每次的情况都存下去. 这里需要注意的是,在保存的时候,我们要保持x的坐标是大于y的,这样方便我们之后的排序. 然后就直接求最长递减子序列就好了. #include<stdio.h> #include<string.h>

hdu 1069 Monkey and Banana (dp)

//把给定的长方体(不限)叠加在一起,叠加的条件是,上面一个长方体的长和宽都比下面长方体的长 /* 分析:因为每块积木最多有3个不同的底面和高度,因此先把每块积木看成三种不同的积木, 每种积木只有一个底面和一个高度.n中类型的积木转化为3*n个不同的积木的叠加, 对这3 * n个积木的长边从大到小排序:接下来的问题就是找到一个递减的子序列, 使得子序列的高度和最大即可. 数组dp:dp[i]表示是以第i块积木为顶的塔的最大高度 因此可得状态转移方程:dp[i] = max(dp[i],dp[j]

HDU 1069 Monkey and Banana(LIS最长上升子序列)

Description 一组研究人员正在设计一项实验,以测试猴子的智商.他们将挂香蕉在建筑物的屋顶,同时,提供一些砖块给这些猴子.如果猴子足够聪明,它应当能够通过合理的放置一些砖块建立一个塔,并爬上去吃他们最喜欢的香蕉. 研究人员有n种类型的砖块,每种类型的砖块都有无限个.第i块砖块的长宽高分别用xi,yi,zi来表示. 同时,由于砖块是可以旋转的,每个砖块的3条边可以组成6种不同的长宽高. 在构建塔时,当且仅当A砖块的长和宽都分别小于B砖块的长和宽时,A砖块才能放到B砖块的上面,因为必须留有一

[2016-03-30][HDU][1069][Monkey and Banana]

时间:2016-03-27 15:19:40 星期日 题目编号:[2016-03-30][HDU][1069][Monkey and Banana] 题目大意:给定n种积木无限个,问这些积木最大能叠多高,上面的积木长宽必须严格小于下面的积木 分析: dp[i]表示第i个积木在顶部时候的最大高度,那么dp[i] = max(dp[i],dp[j] + h[i]);?ji能放在j上面?ji能放在j上面 初始条件就是长宽最大的高度是它自己, #include <algorithm> #include

HDU 1069 Monkey and Banana (动规)

Monkey and Banana Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others) Total Submission(s): 7248    Accepted Submission(s): 3730 Problem Description A group of researchers are designing an experiment to test the IQ of a

HDU 1069 Monkey and Banana(二维偏序LIS的应用)

---恢复内容开始--- Monkey and Banana Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others) Total Submission(s): 13003    Accepted Submission(s): 6843 Problem Description A group of researchers are designing an experiment to te