题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1069

题意就是给你n种长方体每种类型不限制个数,然后我们把它们一个个堆起来,并且要满足下面的要比上面的大,不能相等,求最大能达到的高度;我们可以把这归为动态规划,求最长上升子序列的问题

#include<iostream>
#include<cstdio>
#include<cstring>
#include<cstdlib>
#include<algorithm>
using namespace std;
#define N 220
struct node
{
int x,y,z,v,h;
};
int cmp(node a,node b)
{ return a.v<b.v;
}
int main()
{
int i,j,x,y,z,n,t=;
node a[N];
while(scanf("%d",&n),n)
{
memset(a,,sizeof(a));
j=;
for(i=;i<n;i++)
{
scanf("%d %d %d",&x,&y,&z);
a[j].x=x;a[j].y=y;a[j].z=z;a[j].v=x*y;j++;
a[j].x=y;a[j].y=z;a[j].z=x;a[j].v=y*z;j++;
a[j].x=z;a[j].y=x;a[j].z=y;a[j].v=x*z;j++;
}
sort(a,a+j,cmp);
for(i=;i<n*;i++)
{
int MAX=;
for(j=;j<i;j++)
{
if(((a[i].x>a[j].y&&a[i].y>a[j].x)||(a[i].x>a[j].x&&a[i].y>a[j].y))&&a[j].h>MAX)
{
MAX=a[j].h;
}
}
a[i].h=a[i].z+MAX;
}
int ans=;
for(i=;i<*n;i++)
{
ans=max(ans,a[i].h);
}
t++;
printf("Case %d: maximum height = %d\n",t,ans);
}
return ;
}

后来又写了一遍...都差不多:

#include<stdio.h>
#include<string.h>
#include<algorithm>
#include<math.h>
#include<iostream>
using namespace std;
#define N 1010
struct node
{
int x,y,w;
}a[N]; int cmp(node p, node q)
{
if(p.x != q.x)
return p.x<q.x;
return p.y<q.y;
} int main()
{
int n, x, y, z, dp[N], t=;
while(scanf("%d", &n), n)
{
int k = ;
for(int i=; i<n; i++)
{
scanf("%d%d%d", &x, &y, &z);
if(x>y)swap(x, y);
if(x>z)swap(x, z);
if(y>z)swap(y, z);
a[k].x=x; a[k].y=y; a[k++].w=z;
a[k].x=x; a[k].y=z; a[k++].w=y;
a[k].x=y; a[k].y=z; a[k++].w=x;
}
sort(a, a+k, cmp);
memset(dp, , sizeof(dp));
int ans = ;
for(int i=; i<k; i++)
{
dp[i] = a[i].w;
for(int j=; j<i; j++)
{
if(a[i].x>a[j].x && a[i].y>a[j].y)
dp[i]=max(dp[i], dp[j]+a[i].w);
}
ans = max(ans, dp[i]);///dp[k-1]不一定是最大的;这是突然明白的-_-;
}
printf("Case %d: maximum height = %d\n", t++, ans);
}
return ;
}

Monkey and Banana---hdu1069(dp)的更多相关文章

  1. [LightOJ1004]Monkey Banana Problem(dp)

    题目链接:http://lightoj.com/login_main.php?url=volume_showproblem.php?problem=1004 题意:数塔的变形,上面一个下面一个,看清楚 ...

  2. Light OJ 1004 - Monkey Banana Problem(DP)

    题目大意: 给你一菱形的数字阵,问从最上面走到最下面所能获得的最大值是多少? #include<cstdio> #include<cstring> #include<io ...

  3. hdu1069(dp)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1069 分析: 每种石头有六种方法,那么等效为:有6*n种石头. 根据x和y排序(要保证相应的x.y总有 ...

  4. hdu-1069(dp)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1069 题意:一群猴子,给出n块砖的长x宽y高z,用这些砖拼起的高度最高是多少, 要求底下的砖的长宽都要 ...

  5. LightOJ 1033 Generating Palindromes(dp)

    LightOJ 1033  Generating Palindromes(dp) 题目链接:http://acm.hust.edu.cn/vjudge/contest/view.action?cid= ...

  6. lightOJ 1047 Neighbor House (DP)

    lightOJ 1047   Neighbor House (DP) 题目链接:http://acm.hust.edu.cn/vjudge/contest/view.action?cid=87730# ...

  7. UVA11125 - Arrange Some Marbles(dp)

    UVA11125 - Arrange Some Marbles(dp) option=com_onlinejudge&Itemid=8&category=24&page=sho ...

  8. 【POJ 3071】 Football(DP)

    [POJ 3071] Football(DP) Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 4350   Accepted ...

  9. 初探动态规划(DP)

    学习qzz的命名,来写一篇关于动态规划(dp)的入门博客. 动态规划应该算是一个入门oier的坑,动态规划的抽象即神奇之处,让很多萌新 萌比. 写这篇博客的目标,就是想要用一些容易理解的方式,讲解入门 ...

  10. Tour(dp)

    Tour(dp) 给定平面上n(n<=1000)个点的坐标(按照x递增的顺序),各点x坐标不同,且均为正整数.请设计一条路线,从最左边的点出发,走到最右边的点后再返回,要求除了最左点和最右点之外 ...

随机推荐

  1. Window日志分析

    0X00 简介 0x01 基本设置 A.Windows审核策略设置 前提:开启审核策略,若日后系统出现故障.安全事故则可以查看系统的日志文件,排除故障,追查入侵者的信息等. 打开设置窗口 Window ...

  2. 使用librtmp进行H264与AAC直播

    libx264 版本是 128libfaac 版本是 1.28 1.帧的划分 1.1 H.264 帧 对于 H.264 而言每帧的界定符为 00 00 00 01 或者 00 00 01. 比如下面的 ...

  3. Ora2Pg的安装和使用

    1. 安装DBI,DBD::Oracle DBI只是个抽象层,要实现支持不同的数据库,则需要在DBI之下,编写针对不同数据库的驱动.对MySql来说,有DBD::Mysql, 而对ORACLE来说,则 ...

  4. linux clamav杀毒软件的安装

    一.概述 Linux比其它操作系统更稳定更安全.理论上Linux是有可能被病毒侵害的.但实际上 Linux机器几乎不可能遭受病毒的攻击.所以我这里的问题是为什么要为Linux准备防病毒软件,为了更好理 ...

  5. C语言实现字符串IP与整数型IP的相互转换

    #include <stdio.h> #include <stdlib.h> #include <string.h> #include <malloc.h&g ...

  6. URL地址重写例子(Helicon)

    # Helicon ISAPI_Rewrite configuration file# Version 3.1.0.86 #RewriteEngine on RewriteRule ^/esf/.+( ...

  7. x64枚举DPC定时器

    @写在前面      不同于x86,x64的DPC是被加密了的.对于x64DPC的兴趣始于我已经流产的scalpel计划.当时问某牛怎么遍历,得到的答案是“500大洋给代码”.真是R了狗了,好歹小哥我 ...

  8. Panel结构

    参考weui的Panel结构 核心:定位,补充:对容器设置font-size:0,消除img下多出的3px,防止居中出现偏差. <!DOCTYPE html> <html lang= ...

  9. JavaScript arguments对象详解

    1. 什么是 arguments MDN 上解释: arguments 是一个类数组对象.代表传给一个function的参数列表. 我们先用一个例子直观了解下 JavaScript 中的 argume ...

  10. IIS "rewrite.dll failed to load. The data is the error." 错误解决方法

    在Windows 10 build 17133.73上部署一个较老版本的ASP.NET 2.0程序,访问时候出现: Service Unavailable HTTP Error 503. The se ...