HDU 1069 Monkey and Banana 基础DP
题目链接:Monkey and Banana
大意:给出n种箱子的长宽高。每种不限个数。可以堆叠。询问可以达到的最高高度是多少。
 要求两个箱子堆叠的时候叠加的面。上面的面的两维长度都严格小于下面的。
简单的DP,依然有很多地发给当时没想到。比如优先级,比如这么简单粗暴的选择。
/*
大意是。给出n种箱子的长宽高。每种不限个数。可以堆叠。询问可以达到的最高高度是多少。
要求两个箱子堆叠的时候叠加的面。上面的面的两维长度都严格小于下面的。 样例:
10 20 30
10 20
10 30
20 30
可以摆放的方法:10 20
20 30
高度: 30+10 = 40 /思路:把所有种类的箱子的每个面的两维长度都列出来。n<=30,那么,箱子的面个数<=90。然后按照要求来开始堆叠。
问题是。我应该怎么来找当前最符合条件的呢。从两维长度都最大的开始吗。下一个怎么对应呢。还是应该从面积最大的开始。可能性太多。
以上出自无厘头系列。
/ 思路:给出一种箱子可以看做是三个箱子。(完全相同的两个面是不可能出现两次的。所以一个箱子最多会用三次、)。把所有的箱子按照先长后宽,从大到小排序。
然后(LIS。求最长递减子序列的思路。)dp[i] = j 表示从1到i的前i个(暂且当做从1开始)箱子里。在选第i个的前提下,得到的最大高度。
*/ #include <stdio.h>
#include <string.h>
#include <iostream>
#include <algorithm>
using namespace std; struct Node {
int x, y, z;
}node[]; // 最多90个 bool cmp(Node a, Node b) {
if (a.x != b.x)
return a.x < b.x;
else return a.y < b.y;
} int h[]; int main() {
int n;
int num = ;
while(~scanf("%d", &n)) {
if (n == ) break;
num++;
for (int j=, i=; j<n; ++j) {
int a, b, c;
scanf("%d%d%d", &a, &b, &c);
node[i].x = a, node[i].y = b, node[i].z = c;
node[i+].x = a, node[i+].y = c, node[i+].z = b;
node[i+].x = b, node[i+].y = c, node[i+].z = a;
i += ;
} for (int i=; i<n*; ++i) {
if (node[i].x < node[i].y) {
int temp = node[i].y;
node[i].y = node[i].x;
node[i].x = temp;
}
} sort(node, node+n*, cmp);
int ans = -; for (int i=; i<*n; ++i) {
h[i] = node[i].z;
for (int j=; j<i; ++j) {
if (node[j].x < node[i].x && node[j].y < node[i].y) {
h[i] = max(h[i], h[j]+node[i].z);
}
}
ans = max(ans, h[i]);
} printf("Case %d: maximum height = %d\n", num, ans);
}
return ;
}
HDU 1069 Monkey and Banana 基础DP的更多相关文章
- HDU 1069—— Monkey and Banana——————【dp】
		
Monkey and Banana Time Limit:1000MS Memory Limit:32768KB 64bit IO Format:%I64d & %I64u S ...
 - HDU 1069 Monkey and Banana(DP——最大递减子序列)
		
题目链接: http://acm.split.hdu.edu.cn/showproblem.php?pid=1069 题意描述: 给n块砖,给出其长,宽和高 问将这n块砖,怎样叠放使得满足以下条件使得 ...
 - HDU    1069    Monkey and Banana    (dp)
		
题目链接 Problem Description A group of researchers are designing an experiment to test the IQ of a monk ...
 - HDU 1069 Monkey and Banana  ——(DP)
		
简单DP. 题意:给出若干种长方体,如果摆放时一个长方体的长和宽小于另一个的长宽,那么它可以放在另一个的上面,问最高能放多少高度.每种长方体的个数都是无限的. 做法:因为每种个数都是无限,那么每种按照 ...
 - HDU 1069 Monkey and Banana dp 题解
		
HDU 1069 Monkey and Banana 纵有疾风起 题目大意 一堆科学家研究猩猩的智商,给他M种长方体,每种N个.然后,将一个香蕉挂在屋顶,让猩猩通过 叠长方体来够到香蕉. 现在给你M种 ...
 - HDU 1069 Monkey and Banana / ZOJ 1093 Monkey and Banana (最长路径)
		
HDU 1069 Monkey and Banana / ZOJ 1093 Monkey and Banana (最长路径) Description A group of researchers ar ...
 - HDU 1069 Monkey and Banana(转换成LIS,做法很值得学习)
		
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1069 Monkey and Banana Time Limit: 2000/1000 MS (Java ...
 - HDU 1069 Monkey and Banana (DP)
		
Monkey and Banana Time Limit:1000MS Memory Limit:32768KB 64bit IO Format:%I64d & %I64u S ...
 - HDU 1069 Monkey and Banana(DP 长方体堆放问题)
		
Monkey and Banana Problem Description A group of researchers are designing an experiment to test the ...
 
随机推荐
- SQLAlchemy中scoped_session实现线程安全
			
不多说,先上代码 from sqlalchemy.orm import sessionmaker from sqlalchemy import create_engine from sqlalchem ...
 - D. Little Artem and Dance---cf669D(模拟)
			
题目链接:http://codeforces.com/problemset/problem/669/D 给你n个数,一开始是1 2 3 4 5 6 ... n 这样的 现在有两个操作,第一个操作是所有 ...
 - 以太坊api访问,区块同步监测
			
以太坊geth api访问,区块同步监测 curl查询geth区块高度 supervisor管理以太坊geth进程 geth进程健康检查 # curl访问geth api #使用curl访问geth ...
 - HTTP cookies 详解(国外一位大牛的文章)
			
原文:http://blog.csdn.net/lijing198997/article/details/9378047 HTTP cookies,通常又称作"cookies",已 ...
 - matplotlib-折线图、散点图
			
(一)折线图小结 1.设置图片大小(想要一个高清无码大图) # 图大小 plt.figure(figsize=(20, 8), dpi=80) 2.保存到本地 # 设置图片大小 plt.figure( ...
 - centos   LB负载均衡集群 三种模式区别 LVS/NAT 配置  LVS/DR 配置  LVS/DR + keepalived配置  nginx ip_hash 实现长连接  LVS是四层LB  注意down掉网卡的方法  nginx效率没有LVS高  ipvsadm命令集  测试LVS方法 第三十三节课
			
centos LB负载均衡集群 三种模式区别 LVS/NAT 配置 LVS/DR 配置 LVS/DR + keepalived配置 nginx ip_hash 实现长连接 LVS是四层LB ...
 - php5.6安装gd库
			
rpm -Uvh http://ftp.iij.ad.jp/pub/linux/fedora/epel/6/x86_64/epel-release-6-8.noarch.rpm rpm -Uvh ht ...
 - What do you think the coming adidas NMD Singapore
			
adidas NMD Singapore is surprising everybody with a lot of completely new NMD choices combined with ...
 - jvm之gc日志
			
ava GC日志可以通过 +PrintGCDetails开启 以ParallelGC为例 YoungGC日志解释如下 FullGC:
 - web实现负载均衡的几种实现方式
			
摘要: 负载均衡(Load Balance)是集群技术(Cluster)的一种应用.负载均衡可以将工作任务分摊到多个处理单元,从而提高并发处理能力.目前最常见的负载均衡应用是Web负载均衡.根据实现的 ...