生日蛋糕

Time Limit: 1000MS Memory Limit: 10000K
Total Submissions: 23049 Accepted: 8215

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 = πR2H

侧面积A' = 2πRH

底面积A = πR2

分析

  • 由于要计算表面积(露出来的),那么在一层一层的计算过程中,如果最下面的一层确定了,则上表面积就确定了,所以搜索框架从下到上。
  • 搜索面对的状态有:正在搜索蛋糕第dep层,当前的外表面积,当前的体积,第dep+1层的高度和半径。
  • 在第dep层时,要枚举所有符合要求的高度和半径
    • 半径:\(R\in[dep,min(\lfloor\sqrt{N-v}\rfloor,r[dep+1]-1)]\)
    • 高度:\(H\in[dep,min(\lfloor (N-v)/R^2\rfloor,h[dep+1]-1)]\)
    • 上面两个右边界的式子可以通过圆柱体积公式 \(\pi R^2H =\pi(N-v)\)
  • 在上面确定的范围中,使用倒序枚举。R越大,表面积越小
  • 可行性剪枝
    • 可以预处理出从上往下前 \(i(1\leq i\leq M)\) 层最小体积和侧面积.显然,当第 1~i 层的半径分别取 1,2,3,... ,i,高度也分别取 1,2,3,... ,i,时,有最小体积与侧面积。
    • 如果当前体积加上1~dep-1 层的最小体积大于N,可以剪枝。
  • 最优性剪枝一,如果当前表面积s加上 1~dep-1 层的最小侧面积大于已经搜到的答案,或者当前体积加上1~dep-1 层的最大体积小于 v,剪枝
  • 最优性剪枝二,通过转换可以得到 \(\frac{2(n-v)}{r[dep]} + s\) 大于已经搜到的答案时,可以剪枝。
#define MAX 19931117
int minv[30];
int mins = MAX;
int v,m;
int maxcake (int n, int lr, int lh)
{
int ans = 0, i;
for (i = n, lr--, lh--; i <= m; i++, lr--, lh--)
{
ans += lr * lr * lh;
if (ans >= 10000 || lr * lr * lh >= 10000) return 10000;
}
return ans;
} void dfs(int n,int lr,int lh,int uv,int us)
{
if(us>=mins)return;
if(uv+minv[m-n+1]>v|| uv + maxcake(n, lr, lh) < v)return;
int r,h;
if(n==m)
{
for(r = lr-1;r>=1;r--)
{
if((v-uv)%(r*r))continue;
h=(v-uv)/(r*r);
if(h>=lh)continue;
mins = min(mins,us+2*r*h+(m==1?(r*r):0));
}
return;
}
else
{
for(r = lr-1;r>=m-n+1;r--)
{
for(h=min(lh - 1, (int)((v - uv) / (r * r))); h >= m - n + 1; h--)
{
if (n == 1) dfs(2, r, h, r * r * h, r * r + 2 * r * h);
else dfs(n + 1, r, h, uv + r * r * h, us + 2 * r * h);
}
}
return ;
}
}
int main()
{
cin>>v>>m;
minv[0] = 0;
for(int i = 1;i<=m;i++)
minv[i] = minv[i-1]+i*i*i;
dfs(1,101,10001,0,0);
if(mins==MAX)
cout<<0<<endl;
else
cout<<mins<<endl;
return 0;
}

POJ-1190-生日蛋糕(深搜,剪枝)的更多相关文章

  1. Hdu3812-Sea Sky(深搜+剪枝)

    Sea and Sky are the most favorite things of iSea, even when he was a small child.  Suzi once wrote: ...

  2. poj1190 生日蛋糕(深搜+剪枝)

    题目链接:poj1190 生日蛋糕 解题思路: 深搜,枚举:每一层可能的高度和半径 确定搜索范围:底层蛋糕的最大可能半径和最大可能高度 搜索顺序:从底层往上搭蛋糕,在同一层尝试时,半径和高度都是从大到 ...

  3. 一本通例题-生日蛋糕——题解<超强深搜剪枝,从无限到有限>

    题目传送 显然是道深搜题.由于蛋糕上表面在最底层的半径确认后就确认了,所以搜索时的面积着重看侧面积. 找维度/搜索面临状态/对象:当前体积v,当前外表面面积s,各层的半径r[],各层的高度h[]. 可 ...

  4. Codevs 1710 == POJ 1190 生日蛋糕 == 洛谷P1731

    生日蛋糕 时间限制: 2 s  空间限制: 128000 KB  题目等级 : 大师 Master 题目描述 Description 7月17日是Mr.W的生日,ACM-THU为此要制作一个体积为Nπ ...

  5. UVA 10160 Servicing Stations(深搜 + 剪枝)

    Problem D: Servicing stations A company offers personal computers for sale in N towns (3 <= N < ...

  6. ACM 海贼王之伟大航路(深搜剪枝)

    "我是要成为海贼王的男人!" 路飞他们伟大航路行程的起点是罗格镇,终点是拉夫德鲁(那里藏匿着"唯一的大秘宝"--ONE PIECE).而航程中间,则是各式各样的 ...

  7. hdu 1518 Square(深搜+剪枝)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1518 题目大意:根据题目所给的几条边,来判断是否能构成正方形,一个很好的深搜应用,注意剪枝,以防超时! ...

  8. POJ-1724 深搜剪枝

    这道题目如果数据很小的话.我们通过这个dfs就可以完成深搜: void dfs(int s) { if (s==N) { minLen=min(minLen,totalLen); return ; } ...

  9. 模拟赛T5 : domino ——深搜+剪枝+位运算优化

    这道题涉及的知识点有点多... 所以还是比较有意思的. domino 描述 迈克生日那天收到一张 N*N 的表格(1 ≤ N ≤ 2000),每个格子里有一个非 负整数(整数范围 0~1000),迈克 ...

  10. POJ2044 深搜+剪枝(云彩下雨)

    题意:        有一个城镇,是4*4的大小的,然后你控制一块云彩,2*2的,你每天可以有9种走的方法,上下左右,或者不动,走的时候可以走1或者2步,云彩所在的地方肯定会下雨,然后给你做多365天 ...

随机推荐

  1. mql4入门(1)

    博主比较忙,因此也就抽空写写.等最后全部写完了再汇总一下.     说到金融,我想肯定有很多人印象里就是一个不太大的大厅,一群交易员望着一堆背景为黑的曲线图的场景. 比如这样     但是试想一下,交 ...

  2. POJ1236【图的前连通(缩点)】

    题意: 1.初始至少需要向多少个学校发放软件,使得网络内所有的学校最终都能得到软件. 2.至少需要添加几条传输线路(边),使任意向一个学校发放软件后,经过若干次传送,网络内所有的学校最终都能得到软件. ...

  3. HCNA网工笔记Day2 - IP编址

    IP编址 主机地址子网掩码:区分主机位和网络位网络地址:主机位全部为0,比如 127.0.0.0/8广播地址:主机位全部为1,比如 127.255.255.255/8 一般网络地址和广播地址不能pin ...

  4. 贪心+拓扑排序 AOJ 2456 Usoperanto

    题目传送门 题意:给出一条链,比如x连到y,x一定要在y的左边,且代价是这条链经过的点的权值和,问如何排序使得代价最小 分析:类似拓扑排序,先把入度为0的点入队,把指向该点的所有点按照权值排序,保证这 ...

  5. oracle 查看未关闭连接

    查看连接状态.问题电脑等信息: select sid,serial#,username,program,machine,status from  v$session; 2.查看sql; select ...

  6. vue 模拟后台数据(加载本地json文件)调试

    首先创建一个本地json文件,放在项目中如下 { "runRedLight":{ "CurrentPage": 1, "TotalPages" ...

  7. P1482 Cantor表(升级版)

    题目描述 现代数学的著名证明之一是Georg Cantor证明了有理数是可枚举的.他是用下面这一张表来证明这一命题的: 1/1 1/2 1/3 1/4 1/5 … 2/1 2/2 2/3 2/4 … ...

  8. hihocoder1718 最长一次上升子序列

    思路: 对于每个i,分别求1~i和i+1~N两部分的最长下降子序列“拼”起来,最终取最大长度即可.学习了如何使用BIT把LIS问题O(N2)算法优化为O(Nlog(N))的算法. https://ww ...

  9. java实现排序的几种方法

    package com.ywx.count; import java.util.Scanner; /** * 题目:排序的几种方式(汇总及重构) * @author Vashon(yangwenxue ...

  10. 为Qt添加SSL支持

    目标:为Qt添加SSL支持,使得应用可以发送HTTPS请求 环境:win7,Qt4.8.6 步骤: 1.到http://slproweb.com/products/Win32OpenSSL.html下 ...