博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
HDU 1069 dp最长递增子序列
阅读量:5280 次
发布时间:2019-06-14

本文共 3420 字,大约阅读时间需要 11 分钟。

B - Monkey and Banana
Time Limit:1000MS     Memory Limit:32768KB     64bit IO Format:%I64d & %I64u
Submit
Appoint description:

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 enough, it shall be able to reach the banana by placing one block on the top another to build a tower and climb up to get its favorite food.
The researchers have n types of blocks, and an unlimited supply of blocks of each type. Each type-i block was a rectangular solid with linear dimensions (xi, yi, zi). A block could be reoriented so that any two of its three dimensions determined the dimensions of the base and the other dimension was the height.
They want to make sure that the tallest tower possible by stacking blocks can reach the roof. The problem is that, in building a tower, one block could only be placed on top of another block as long as the two base dimensions of the upper block were both strictly smaller than the corresponding base dimensions of the lower block because there has to be some space for the monkey to step on. This meant, for example, that blocks oriented to have equal-sized bases couldn't be stacked.
Your job is to write a program that determines the height of the tallest tower the monkey can build with a given set of blocks.
 

Input

The input file will contain one or more test cases. The first line of each test case contains an integer n,
representing the number of different blocks in the following data set. The maximum value for n is 30.
Each of the next n lines contains three integers representing the values xi, yi and zi.
Input is terminated by a value of zero (0) for n.
 

Output

For each test case, print one line containing the case number (they are numbered sequentially starting from 1) and the height of the tallest possible tower in the format "Case case: maximum height = height".
 

Sample Input

1 10 20 30 2 6 8 10 5 5 5 7 1 1 1 2 2 2 3 3 3 4 4 4 5 5 5 6 6 6 7 7 7 5 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
 
 
每个格子可以形成6种状态,最多有180种状态,,,,,,,对X,Y作为判断条件进行判断,累加Z值
#include
#include
#include
#include
using namespace std;struct node{ int x,y,z;}que[200];int dp[200];int tot;void addedge(int x,int y,int z){ que[tot].x=x; que[tot].y=y; que[tot++].z=z; que[tot].x=x; que[tot].y=z; que[tot++].z=y; que[tot].x=y; que[tot].y=x; que[tot++].z=z; que[tot].x=y; que[tot].y=z; que[tot++].z=x; que[tot].x=z; que[tot].y=x; que[tot++].z=y; que[tot].x=z; que[tot].y=y; que[tot++].z=x;}bool cmp(struct node t1,struct node t2){ if(t1.x!=t2.x) return t1.x>t2.x; else if(t1.x==t2.x&&t1.y!=t2.y) return t1.y>t2.y; else return t1.z>t2.z;}int main(){ int n; int cas=1; while(scanf("%d",&n)!=EOF){ if(!n) break; memset(dp,0,sizeof(dp)); tot=1; int x,y,z; for(int i=0;i
=1;j--){ if(que[i].x

 

 

转载于:https://www.cnblogs.com/13224ACMer/p/5351815.html

你可能感兴趣的文章
CSS层模型
查看>>
springBoot 项目 jar/war打包 并运行
查看>>
HDU 1501 Zipper
查看>>
打包java程序生成exe
查看>>
八叉树
查看>>
poj 1129 搜索
查看>>
Git 远程仓库
查看>>
HttpClient的巨坑
查看>>
关于静态文本框透明度的问题
查看>>
海量数据、高并发的优化方案
查看>>
javascript的发展及个人笔记
查看>>
全选,反全选,反选,获取选中的值,根据子选择控制全选按钮
查看>>
梦断代码读后感01
查看>>
[CF#250 Div.2 D]The Child and Zoo(并查集)
查看>>
博客园博客插入公式
查看>>
hdu 1028 Ignatius and the Princess III(母函数入门+模板)
查看>>
Ubuntu下配置安装telnet server
查看>>
Codeforces 235 E Number Challenge
查看>>
ubuntu 常见命令整理
查看>>
EJBCA安装教程+postgresql+wildfly10
查看>>