题目链接: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. 【代码审计】UKCMS_v1.1.0 文件上传漏洞分析

      0x00 环境准备 ukcms官网:https://www.ukcms.com/ 程序源码下载:http://down.ukcms.com/down.php?v=1.1.0 测试网站首页: 0x0 ...

  2. error: pathspec 'master' did not match any file(s) known to git.

    问题描述: 在远程服务器上新建裸仓库git  --bare init : git clone裸仓库到本地: 本地新建并切换分支xccdev,git checkout -b xccdev: 从xccde ...

  3. Selenium 基本用法

    如下,使用 Selenium 打开淘宝首页并获取页面源代码: from selenium import webdriver browser = webdriver.Chrome() # 声明一个浏览器 ...

  4. C#中的垃圾回收机制与delegate

    在DeepStream的C#版本调试过程中,发现了一个问题,运行一段时间后,大概每次内存到16M(Debug模式)就会异常 错误“System.NullReferenceException:未将对象引 ...

  5. VS无法导航到插入点F12失败

    关闭VS 开启控制台并导航到Visual安装文件夹,例如C:\Program Files (x86)\Microsoft Visual Studio\2017\Community\Common7\ID ...

  6. Kafka 0.11客户端集群管理工具AdminClient

    很多用户都有直接使用程序API操作Kafka集群的需求.在0.11版本之前,kafka的服务器端代码(即添加kafka_2.**依赖)提供了AdminClient和AdminUtils可以提供部分的集 ...

  7. js控制滚动条的位置以及隐藏滚动条

    document.documentElement.style.overflow = 'hidden'; //隐藏横竖滚动条 window.scrollTo(0,document.body.scroll ...

  8. 简单的Excel导入(上传、解析、持久化)

    /** * excel导入 * @param req * @param resp * @return */ public void excelImport(){ //先将要上传的Excel文件上传到项 ...

  9. 节日换肤通用技术方案__iOS端实现

    一.问题的提出 不知道大家有没有发现, 元旦期间, 很多APP界面里的图标都换成了具有节日气氛的样式, 而在过了元旦节之后, 这些图标又悄无声息的变回了本来的面貌. 这些具有短暂生命周期.而又必须在固 ...

  10. phaser相关

    phaser.js这个插件,中文翻译的开发文档还在翻译中,至于英文的开发文档,勉勉强强查阅,有些方法名和开发文档的有着一些区别,开发文档上时带着er的.不过大体上还是一一对应查找的到的 eg:load ...