生日蛋糕—dfs

时间:2022-04-03 23:27:24

Description

7月17日是Mr.W的生日,ACM-THU为此要制作一个体积为Nπ的M层生日蛋糕,每层都是一个圆柱体。 
设从下往上数第i(1 <= i <= M)层蛋糕是半径为Ri, 高度为Hi的圆柱。当i < M时,要求Ri > Ri+1且Hi > Hi+1。 
由于要在蛋糕上抹奶油,为尽可能节约经费,我们希望蛋糕外表面(最下一层的下底面除外)的面积Q最小。 
令Q = Sπ 
请编程对给出的N和M,找出蛋糕的制作方案(适当的Ri和Hi的值),使S最小。 
(除Q外,以上所有数据皆为正整数) 

Input

有两行,第一行为N(N <= 10000),表示待制作的蛋糕的体积为Nπ;第二行为M(M <= 20),表示蛋糕的层数为M。

Output

仅一行,是一个正整数S(若无解则S = 0)。

Sample Input

100
2

Sample Output

68

Hint

圆柱公式 
体积V = πR2
侧面积A' = 2πRH 
底面积A = πR2 
#include<iostream>
#include<stdio.h>
#include<string.h>
using namespace std;
const int N=;
const int inf=0x3f3f3f3f;
int mins[N],minv[N];
int ans,n,m;
void init()
{
int i;
mins[]=;
minv[]=;
for(i=;i<N;i++)//从顶层向下计算出最小的面积和体积值,都提出pi处理
{
mins[i]=mins[i-]+*i*i;
minv[i]=minv[i-]+i*i*i;
}
}
从m层向上搜索,dep是当前层数,sums,sumv指搜索到现在的面积和体积的值,r,h指当前层的半径和高度
void dfs(int dep,int sums,int sumv,int r,int h)
{
int maxh,i,j;
if(dep==)//搜索完成了,dep==0;
{
if(sumv==n&&sums<ans)//此时sumv==n,若面积比当前ans小的话,更新ans;
{
ans=sums;
}
return ;
}
if(sums+mins[dep-]>ans||sumv+minv[dep-]>n||*(n-sumv)/r+sums>=ans) return ;
//三个重要的剪枝,当前面积加上上面几层最小的可能面积大于ans;同理,体积;ans-sums>2*(n-sumv)/r;
for(i=r-;i>=dep;i--)
{
if(dep==m)//如果是最底下的那层,先加上他的上面的面积,这样以后就只要考虑侧面的面积就可以了
{
sums=i*i;
}
maxh=min(h-,(n-sumv-minv[dep-])/(i*i));//去最小值做最大高度h=v/(r*r)
for(j=maxh;j>=dep;j--)
{
dfs(dep-,sums+*i*j,sumv+i*i*j,i,j);//到上一层搜索
}
}
} int main()
{
init();
while(~scanf("%d%d",&n,&m))
{
ans=inf;
dfs(m,,,n+,n+);
if(ans==inf) ans=;
printf("%d\n",ans);
}
return ;
}

生日蛋糕—dfs的更多相关文章

  1. POJ1190生日蛋糕&lbrack;DFS 剪枝&rsqb;

    生日蛋糕 Time Limit: 1000MS   Memory Limit: 10000K Total Submissions: 18236   Accepted: 6497 Description ...

  2. poj1190 生日蛋糕 dfs

    题意:生日蛋糕有m层,总体积是V.从下向上,每一层的半径r和高度h都是递减的. 给m.v,求最小的表面积s.(不算底面接地的面积) 题目链接:poj1190 剪枝都还没加..样例输出都是错的...还没 ...

  3. 生日蛋糕&lpar;DFS&rpar;

    题意: Description 7月17日是Mr.W的生日,ACM-THU为此要制作一个体积为Nπ的M层生日蛋糕,每层都是一个圆柱体.   设从下往上数第i(1 <= i <= M)层蛋糕 ...

  4. &lbrack;洛谷P1731&rsqb;&lbrack;NOI1999&rsqb;生日蛋糕&lpar;dfs&rpar;&lpar;剪枝&rpar;

    典型的深搜+剪枝策略 我们采用可行性剪枝.上下界剪枝.优化搜索顺序剪枝.最优性剪枝的方面来帮助我们进行剪枝. 也许有人还不知道剪枝,那我就弱弱地为大家补习一下吧qwq: .优化搜索顺序: 在一些搜索问 ...

  5. 洛谷P1731生日蛋糕&lpar;dfs&plus;剪枝&rpar;

    P1731 生日蛋糕 题目背景 7月17日是Mr.W的生日,ACM-THU为此要制作一个体积为Nπ的M层 生日蛋糕,每层都是一个圆柱体. 设从下往上数第i(1<=i<=M)层蛋糕是半径为R ...

  6. POJ - 1190 生日蛋糕 dfs&plus;剪枝

    思路:说一下最重要的剪枝,如果当前已经使用了v的体积,为了让剩下的表面积最小,最好的办法就是让R尽量大,因为V = πR 2H,A' = 2πRH,A' = V / R * 2 ,最大的R一定是取当前 ...

  7. &lbrack;POJ1190&rsqb;生日蛋糕&lt&semi;DFS&gt&semi;

    题目链接:http://poj.org/problem?id=1190 题看上去确实很复杂 涉及到半径面积这些,其实看着真的很头疼 但是除去这些就是剪枝优化的dfs算法 #include<cst ...

  8. POJ 1190 生日蛋糕(DFS)

    生日蛋糕 Time Limit: 1000MSMemory Limit: 10000KB64bit IO Format: %I64d & %I64u Submit Status Descrip ...

  9. 【dfs】p1731 生日蛋糕

    1441:[例题2]生日蛋搞 [题目描述] 7月17日是Mr.W的生日,ACM-THU为此要制作一个体积为Nπ的M层生日蛋糕,每层都是一个圆柱体.设从下往上数第i(1≤i≤M)层蛋糕是半径为Ri, 高 ...

随机推荐

  1. &period;Net Core 系列:1、环境搭建

    前言: 2016年6月28日微软宣布发布 .NET Core 1.0.ASP.NET Core 1.0 和 Entity Framework Core 1.0. .NET Core是微软在两年前发起的 ...

  2. document&period;location&period;reload&lpar;&rpar;&semi;与location&period;href&equals;&&num;39&semi;xxx&&num;39&semi;的区别

    document.location.reload();会重新加载页面,onload事件会被触发. location.href='xxx'刷新页面,onload事件不会触发.

  3. Javascript生成GUID

    GUID(全球唯一标识)是微软使用的一个术语,由一个特定的算法,给某一个实体,如Word文档,创建一个唯一的标识,GUID值就是这个唯一的标识码.除了.Net有专门的方法生成外,JS也可以生成GUID ...

  4. poj3211

    Washing Clothes Time Limit: 1000MS   Memory Limit: 131072K Total Submissions: 9654   Accepted: 3095 ...

  5. 基于BaseHTTPServer的简单存储服务器

    服务器代码: from BaseHTTPServer import BaseHTTPRequestHandler from BaseHTTPServer import HTTPServer impor ...

  6. sublime实现markdown浏览器预览

    效果预览 实现 首先下载插件OmniMarkupPreviewer 方法:ctrl + shift + P 安装完成后搜索'OmniMarkupPreviewer'双击即可 下载完成后新建.md文件 ...

  7. &lbrack;PKUWC2019&rsqb;Day1 T2 你和虚树的故事

    选择k个颜色,使得颜色的虚树有交的方案数 肯定要考虑连通块的贡献. 法一 https://www.cnblogs.com/xzz_233/p/10292983.html 枚举连通块还是不可行的. 枚举 ...

  8. Java开发笔记(四十九)关键字super的用法

    前面介绍了如何从Bird类继承而来Swallow类,按道理子类应当继承父类的所有要素,但是对于构造方法来说,Swallow类仅仅继承了Bird类的默认构造方法,并未自动继承带参数的构造方法.如果子类想 ...

  9. HDU3974 Assign the task

    Assign the task Time Limit: 15000/5000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) ...

  10. hibernate状态转换关系图【原】

    hibernate状态转换 其它参考 简单理解Hibernate三种状态的概念及互相转化 简单的Hibernate入门介绍