专题三--1005

题目

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

思路

给出多种木块,每种木块有无数多个,求木块可垒成的最大高度。
每种木块有三种摆放方式,当一个木块有两个边都大于另一个木块时,两木块相容。
将每个木块分解为三个木块之后(三种摆放方式),就形成了一个类似于DAG上的最长路的问题(两个木块之间是二元关系且不会形成环)。使用动态规划来来考虑的话,状态转移方程是

dp[i]=max{dp[j]+b[i].height,j为与i块木块相容的木块的序号}

需要注意的几点是:

  1. dp之前要先对木块进行排序,确保在进行外层的遍历时,与i相容的木块都在i之前,i之后不会出现于i相容的木块
  2. 注意木块相容的判断条件,只要两条边都大即可,不必严格地宽大于宽,长大于长。

AC代码

  1. #include<iostream>
  2. #include<algorithm>
  3. #include<stdio.h>
  4. using namespace std;
  5. struct block{
  6. int c;
  7. int k;
  8. int g;
  9. };
  10. bool cmp(block a,block b){
  11. if((a.c*a.k)<(b.c*b.k)){
  12. return 1;
  13. }
  14. else return 0;
  15. }
  16. int MAX(int a,int b){
  17. return a>b?a:b;
  18. }
  19. int main(){
  20. int n;
  21. struct block tem;
  22. struct block a[300];
  23. int dp[300];
  24. int flag=0;
  25. //freopen("date.in","r",stdin);
  26. //freopen("date.out","w",stdout);
  27. while(cin>>n&&n!=0){
  28. flag++;
  29. for(int i=1;i<=n;i++){
  30. cin>>tem.c>>tem.k>>tem.g;
  31. a[i*3].c=tem.c;a[i*3].k=tem.k;a[i*3].g=tem.g;
  32. //a[i*6-1].c=tem.c;a[i*6-1].k=tem.g;a[i*6-1].g=tem.k;
  33. a[i*3-1].c=tem.k;a[i*3-1].k=tem.g;a[i*3-1].g=tem.c;
  34. //a[i*6-3].c=tem.k;a[i*6-3].k=tem.c;a[i*6-3].g=tem.g;
  35. a[i*3-2].c=tem.g;a[i*3-2].k=tem.c;a[i*3-2].g=tem.k;
  36. //a[i*6-5].c=tem.g;a[i*6-5].k=tem.k;a[i*6-5].g=tem.c;
  37. }
  38. sort(a+1,a+3*n+1,cmp);
  39. /*for(int i=1;i<=3*n;i++){
  40. cout<<a[i].c<<"\t"<<a[i].k<<"\t"<<a[i].g<<"\t"<<endl;
  41. }*/
  42. /*for(int i=1;i<=n;i++)
  43. dp[i]=a[i].g;*/
  44. for(int i=1;i<=3*n;i++){
  45. dp[i]=a[i].g;
  46. for(int j=i-1;j>=1;j--){
  47. if(a[i].c>a[j].c&&a[i].k>a[j].k||a[i].c>a[j].k&&a[i].k>a[j].c)
  48. dp[i]=MAX(dp[j]+a[i].g,dp[i]);
  49. }
  50. }
  51. sort(dp+1,dp+3*n+1);
  52. cout<<"Case "<<flag<<": maximum height = "<<dp[3*n]<<endl;
  53. }
  54. }


来自为知笔记(Wiz)


转载于:https://www.cnblogs.com/liuzhanshan/p/5544418.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/287506.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

shell中的数字

shell中的数字 author :headsen chen date :2017-10-18 15:01:42 个人原创&#xff0c;转载请注明作者&#xff0c;出处&#xff0c;否则依法追究法律责任 1,生成随机数&#xff08;范围&#xff1a;0-32767&#xff09;&#xff0c;用特殊变量&#xff1a;RANDOM 2&#xff…

serviceloader java_【java编程】ServiceLoader使用看这一篇就够了

转载:https://www.jianshu.com/p/7601ba434ff4想必大家多多少少听过spi&#xff0c;具体的解释我就不多说了。但是它具体是怎么实现的呢&#xff1f;它的原理是什么呢&#xff1f;下面我就围绕这两个问题来解释&#xff1a;实现: 其实具体的实现类就是java.util.ServiceLoader…

.NET7 Preview4 之OpenAPI swagger改进

在MiniAPI系列中&#xff0c;《.NET6之MiniAPI(十八)&#xff1a;OpenAPI swagger》介绍了swagger在MiniAPI框架中的使用&#xff0c;当时留下很多不足&#xff0c;随着.NET7 Preview4的推出&#xff0c;这方面得到了很大的改进&#xff0c;我还是使用“十八”这篇文章的案例。…

Swift - 自定义单元格实现微信聊天界面

1&#xff0c;下面是一个放微信聊天界面的消息展示列表&#xff0c;实现的功能有&#xff1a; &#xff08;1&#xff09;消息可以是文本消息也可以是图片消息&#xff08;2&#xff09;消息背景为气泡状图片&#xff0c;同时消息气泡可根据内容自适应大小&#xff08;3&#x…

[python opencv 计算机视觉零基础到实战] 十三 直方图颜色提鲜

一、学习目标 了解了均衡化的作用是什么了解灰度、YUV、彩色图片均衡化的方法是使用什么方法了解了合并通道的方法是什么了解了分离通道的方法是什么 如有错误欢迎指出~ 二、了解图像均衡化 2.1 了解直方图均衡化 图像直方图均衡化主要是对图像中的少数灰度进行压缩&#…

java 中字符串比较方法_java中常用的字符串的比较方法(两种)

比较字符串比较常用的两个方法是运算符“”和String的equals方法。使用“”比较两个字符串&#xff0c;是比较两个对象的的“地址”是否一致&#xff0c;本质就是判断两个变量是否指向同一个对象&#xff0c;如果是则返回true&#xff0c;否则返回的是false。而String类的equal…

Android之稍微靠谱点的透明Activity(不获取触摸事件)

1 问题 实现透明的Activity(不获取触摸事件),就行什么也看不到,打开了透明activity,也不影响其他页面的滑动和点击,就行什么事情都没发生一样。 2 代码实现 1)配置样式 <style name="TestTheme" parent="Theme.AppCompat.Light"><item na…

分布式服务框架dubbo原理解析 转

alibaba有好几个分布式框架&#xff0c;主要有&#xff1a;进行远程调用(类似于RMI的这种远程调用)的(dubbo、hsf)&#xff0c;jms消息服务(napoli、notify)&#xff0c;KV数据库(tair)等。这个框架/工具/产品在实现的时候&#xff0c;都考虑到了容灾&#xff0c;扩展&#xff…

【倾情奉献】遥感物候研究:30年长时间序列遥感数据集GIMMS 3g NDVI产品预处理完整步骤

本文为作者硕士学位论文遥感物候研究数据处理过程总结。GIMMS(Global Inventory Modelling and Mapping Studies) 3g NDVI来源于ECOCAST网站(http://ecocast.arc.nasa.gov),是由NOAA卫星搭载的AVHRR传感器获取的全球植被数据,空间分辨率为0.0833 ,时间分辨率为15 d,一…

过早的给方法中 引用对象 设为 null 可被 GC提前回收吗?

经常在代码中看到有人将 null 赋值给引用类型&#xff0c;来达到让 GC 提前回收的目的&#xff0c;这样做真的有用吗&#xff1f;今天我们就来研究一下。为了方便讲解&#xff0c;来一段测试代码&#xff0c;提前将 test1null &#xff0c;然后调用 GC.Collect() 看看是否能提前…

[python opencv 计算机视觉零基础到实战] 十五 直方图反向投影

一、学习目标 了解了直方图反向投影的一般流程了解2D直方图的使用 如有错误欢迎指出~ 二、了解直方图反向投影 2.1 了解2D直方图 需要对直方图进行反向投影&#xff0c;需要使用2D直方图。2D直方图需要使用calcHist方法。calcHist方法在前两节中已经有了解&#xff0c;现在…

关联规则java代码_重量挖掘关联规则挖掘方法,哪个大神可以将以下伪代码转换为Java代码?...

重量挖掘关联规则挖掘方法&#xff0c;哪个大神可以将以下伪代码转换为Java代码&#xff1f; 10改进的加权关联规则算法的基本步骤与Apriori算法相似: 首先找到加权支持度不小于用户指定的最小加权支持度的所有频繁项集加权关联规则&#xff0c;然后使用频繁项集生成所有满足最…

Boostrap ZURB Foundation —— Web开发前端框架

webflow&#xff1a;Webflow 允许设计师通过自由的拖拉拽与 CSS 类互动&#xff0c;而定义它们的过程无需写任何一行代码。用户在完成从设计到 CSS 构架之后&#xff0c;甚至可以在线直接将建好的网页发布&#xff0c;而不需要导出代码到其他发布工具上。类似的这些 B2D 市场&a…

Git之HEAD和origin

1 问题 我们经常看见git相关操作里面看到HEAD和origin这些专业名称&#xff0c;它娘的到底什么意思。 2 解释 1&#xff09;HEAD git 中的分支&#xff0c;本质上仅仅是个指向 commit 对象的可变指针&#xff0c; HEAD 是一个特别指针&#xff0c;它是一个指向你正在工作中的…

如何离线安装chrome插件

如何离线安装chrome插件 本文转自Work Hard Work Smart博客园博客&#xff0c;原文链接&#xff1a;http://www.cnblogs.com/linlf03/p/6838852.html&#xff0c;如需转载请自行联系原作者

多种语言《九九乘法表》荟萃:C、C++、C#、JavaScript、SQL、VB、VBA、Python

九九乘法表对于我们学习循环结构,尤其是双重循环特别有帮助,本文演示用C、C++、C#、HTML、SQL、VB、VBA、Python等多种语九九乘法表。 一、C语言 #include<stdio.h> main() {int i,j;for(i=1;i<=9;i++){for(j=1;j<=i;j++){printf("%d*%d=%d\t",j,i,i*j…

Git之删除远程分支

1 问题 在工作区间删除远程分支 2 删除命令 git push origin --delete name

iptables (2) 基本配置

iptables 基本命令使用举例 一、链的基本操作 1、清除所有的规则。1&#xff09;清除预设表filter中所有规则链中的规则。# iptables -F -F, --flush [chain]Flush the selected chain (all the chains in the table if none is given). This is equivalent to deleting all …

[python opencv 计算机视觉零基础到实战] 十六、用opencv画画

一、学习目标 了解如何使用line方法了解如何使用rectangle方法了解如何使用ellipse方法 如有错误欢迎指出~ 二、了解OpenCV的绘图方法 2.1 了解直线绘图方法 我们在前两节中有了解使用OpenCV中的矩形绘制&#xff0c;接下来我们了解一下更多的图形绘制方法。我们在OpenCV中…