HDU 1069 Monkey and Banana

HDU 1069 Monkey and Banana

大家好,又见面了,我是全栈君,祝每个程序员都可以多学几门语言。

题意:给你一个数n,接下来给你一个矩形体的3边长(即随便你怎么放它,它的高度有可能是3边中的一条边),如今要你求出这n个矩形体能堆成一座塔的最高高度(塔就是面积从店面開始向上严格递增)

思路:动规里的最长子序列的变形,结合了贪心的思想。首先我们须要对你所用的高进行排序,排序之后找出最严格递减的面积就能够了

AC代码:

#include<iostream>
#include<cstdio>
#include<algorithm>
#include<cstring>
using namespace std;
struct node
{
    int l,w,h;
}box[111];
int dp[111];
bool cmp(node a,node b)
{
   if(a.l>b.l) return true;
   if(a.l==b.l&&a.w>b.w) return true;
   return false;
}
int main()
{
    int d[3],n,i,j,c=1,k,sumh;
	while(scanf("%d",&n)!=EOF&&n)
	{
	    k=0;
		for(i=0;i<n;i++)    
		{
		    scanf("%d%d%d",&d[0],&d[1],&d[2]);
			sort(d,d+3);
			box[k].l=d[2];box[k].w=d[1];box[k].h=d[0];k++;  //每一个矩形体有3中放的方式
			box[k].l=d[2];box[k].w=d[0];box[k].h=d[1];k++;
			box[k].l=d[1];box[k].w=d[0];box[k].h=d[2];k++;
		}
		sort(box,box+k,cmp);
	/*	for(i=0;i<k;i++)
            printf("%d %d %d\n",box[i].l,box[i].w,box[i].h);*/
		for(i=0;i<k;i++) dp[i]=box[i].h;
		for(i=k-2;i>=0;i--)
			for(j=i+1;j<k;j++)
			{
			   if(box[i].l>box[j].l&&box[i].w>box[j].w) //寻求严格递减的面积
				   if(dp[i]<dp[j]+box[i].h)
					   dp[i]=dp[j]+box[i].h;
			}
        sumh=dp[0];
        for(i=0;i<k;i++)
            if(sumh<dp[i]) sumh=dp[i];
        printf("Case %d: maximum height = %d\n",c++,sumh);
	}
   return 0;
}

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/118679.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 积分中值定理_三个中值定理的公式

    积分中值定理_三个中值定理的公式设$f:[a,b]\to\mathbf{R}$是区间$[a,b]$上的连续函数,其中$a,b\in\mathbf{R}$且$a<b$.则存在$a<\varepsilon<b$,使得

    2022年8月4日
    3
  • ant-design-vue文档_antdesign原型设计

    ant-design-vue文档_antdesign原型设计antdesignofvue文件上传action设置上传的地址headers设置上传的请求头部fileList接收已经上传的文件列表(受控)可以控制文件数量事件change记录上传文件改变时的状态,当status为‘done’时将文件列表的地址存到表单中,随表单提交至后台数据库具体用法参考antdesign官网:https://www.antdv.com/components/upload-cn/…

    2022年8月15日
    2
  • MapReduce InputFormat之FileInputFormat

    一:简单认识InputFormat类InputFormat主要用于描述输入数据的格式,提供了以下两个功能:1)、数据切分,按照某个策略将输入数据且分成若干个split,以便确定MapTask的个数即Mapper的个数,在MapReduce框架中,一个split就意味着需要一个MapTask;2)为Mapper提供输入数据,即给定一个spli…

    2022年4月6日
    36
  • 机器学习的分类与主要算法对比[通俗易懂]

    机器学习的分类与主要算法对比[通俗易懂]机器学习的分类与主要算法对比重要引用:AndrewNgCoureraMachineLearning;从机器学习谈起;关于机器学习的讨论;机器学习常见算法分类汇总;LeNetHomepage;pluskidsvm  首先让我们瞻仰一下当今机器学习领域的执牛耳者:  这幅图上的三人是当今机器学习界的执牛耳者。中间的是GeoffreyHinton,加拿大多伦多大学的教授,如今被聘为“Goo

    2022年6月18日
    34
  • oracle创建数据库的三种方法[通俗易懂]

    oracle创建数据库的三种方法[通俗易懂]新建Oracle数据库三种方法:1.通过运行OracleDatabaseConfigurationAssistant创建配置或删除数据库(也可在命令行下输入dbca);2.用命令行的方式建立

    2022年7月4日
    30
  • 栈 数据结构_单调栈和单调队列

    栈 数据结构_单调栈和单调队列单调栈笔者在做leetcode的题(下一个出现的最大数字)时,接触到了单调栈这一种数据结构,经过研究之后,发现单调栈在解决某些问题时出奇的好用,下面是对单调栈的性质和一些典型题目。什么是单调栈?从名字上就听的出来,单调栈中存放的数据应该是有序的,所以单调栈也分为单调递增栈和单调递减栈单调递增栈:数据出栈的序列为单调递增序列单调递减栈:数据出栈的序列为单调递减序列ps:这里一定要注意…

    2022年4月19日
    27

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号