您的位置:首页 > 其它

poj 1190 生日蛋糕 dfs剪枝

2012-10-04 17:41 288 查看
/*
大神的剪枝。。。

估计好下界 进行剪枝。

2*v/R+tmp>=ans; 2*v/R为估计的剩下的能表面积下界。。虽然这个下界是不可达的,
*/
#include <iostream>
#include<cstdio>
#include<cstring>
using namespace std;
int R,H,n,m,ans,mv[21],tmp;
void dfs(int v,int dep,int R,int H) {
if (dep==0) {
if (v==0 && tmp<ans) ans=tmp;
return;
}
//神剪。。
if (v-mv[dep-1]<0 || tmp>=ans || 2*v/R+tmp>=ans) return;
//枚举r与h..
for (int r=R-1;r>=dep;r--) {
int Hm = min(H-1,(v-mv[dep-1])/r/r);
for (int h=Hm;h>=dep;h--)
if ((v-r*r*h)>=0) {
if (dep==m) tmp=r*r;
tmp+=2*r*h;
dfs(v-r*r*h,dep-1,r,h);
tmp-=2*r*h;
if (dep==m) tmp=0;
}
}
}
int main() {
memset(mv,0,sizeof(mv));
for (int i=1;i<=m;i++)
mv[i]=mv[i-1]+i*i*i;//体积下界
while (~scanf("%d%d",&n,&m)) {
ans=10000000;
dfs(n,m,n+1,n+1);
if (ans==10000000) printf("0\n");
else printf("%d\n",ans);
}
return 0;
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: