hdu 1069 Monkey and Banana (dp)

//把给定的长方体(不限)叠加在一起,叠加的条件是,上面一个长方体的长和宽都比下面长方体的长
/*
分析:因为每块积木最多有3个不同的底面和高度,因此先把每块积木看成三种不同的积木,
每种积木只有一个底面和一个高度。n中类型的积木转化为3*n个不同的积木的叠加,
对这3 * n个积木的长边从大到小排序;接下来的问题就是找到一个递减的子序列,
使得子序列的高度和最大即可。
数组dp:dp[i]表示是以第i块积木为顶的塔的最大高度
因此可得状态转移方程:dp[i] = max(dp[i],dp[j] + r[i].z)(满足积木j的底面长和宽都大于积木i的长和宽)
和宽短;求这些长方体能叠加的最高的高度.
*/
# include <stdio.h>
# include <string.h>
# include <algorithm>
using namespace std;
struct node
{
    int x;
    int y;
    int z;
};
struct node r[100010];
bool cmp(node a1,node a2)
{
    if(a1.x!=a2.x)
        return a1.x>a2.x;
    return a1.y>a2.y;
}
int main()
{
    int cas=0;
    int i,j,n,a,b,c,maxh;
    int dp[100010];
    while(~scanf("%d",&n),n)
    {
        for(i=0,j=0; i<n; i++)
        {
            scanf("%d%d%d",&a,&b,&c);
            r[j].x=min(a,b);
            r[j].y=max(a,b);
            r[j].z=c;
            r[j+1].x=min(a,c);
            r[j+1].y=max(a,c);
            r[j+1].z=b;
            r[j+2].x=min(b,c);
            r[j+2].y=max(b,c);
            r[j+2].z=a;
            j+=3;
        }
        n=j;
        sort(r,r+n,cmp);
        for(i=0; i<n; i++)
            dp[i]=r[i].z;
        maxh=0;
        for(i=0; i<n; i++)
        {
            for(j=i-1; j>=0; j--)
            {
                if(r[j].x>r[i].x&&r[j].y>r[i].y)
                {
                    if(dp[j]+r[i].z>dp[i])
                        dp[i]=dp[j]+r[i].z;
                }

            }
            if(maxh<dp[i])
                maxh=dp[i];

        }
        printf("Case %d: maximum height = %d\n",++cas,maxh);
    }
    return 0;
}

时间: 2024-08-02 18:32:02

hdu 1069 Monkey and Banana (dp)的相关文章

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 DP LIS变形题

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

HDU 1069 monkey an banana DP LIS

Time Limit:1000MS     Memory Limit:32768KB     64bit IO Format:%I64d & %I64uDescription 一组研究人员正在设计一项实验,以测试猴子的智商.他们将挂香蕉在建筑物的屋顶,同时,提供一些砖块给这些猴子.如果猴子足够聪明,它应当能够通过合理的放置一些砖块建立一个塔,并爬上去吃他们最喜欢的香蕉. 研究人员有n种类型的砖块,每种类型的砖块都有无限个.第i块砖块的长宽高分别用xi,yi,zi来表示. 同时,由于砖块是可以旋转

[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 基础DP

题目链接:Monkey and Banana 大意:给出n种箱子的长宽高.每种不限个数.可以堆叠.询问可以达到的最高高度是多少. 要求两个箱子堆叠的时候叠加的面.上面的面的两维长度都严格小于下面的. 简单的DP,依然有很多地发给当时没想到.比如优先级,比如这么简单粗暴的选择. 1 /* 2 大意是.给出n种箱子的长宽高.每种不限个数.可以堆叠.询问可以达到的最高高度是多少. 3 要求两个箱子堆叠的时候叠加的面.上面的面的两维长度都严格小于下面的. 4 5 样例: 6 10 20 30 7 10

DP [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): 7854    Accepted Submission(s): 4051 Problem Description A group of researchers are designing an experiment to test the IQ of a

hdu 1069 Monkey and Banana (结构体排序,也属于简单的dp)

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