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; }
相关文章推荐
- poj 1190 生日蛋糕 , 强剪枝
- [POJ 1190] 生日蛋糕
- POJ-1190-生日蛋糕-DFS(深搜)-枚举-多重剪枝
- poj 1190 生日蛋糕 隐式图搜索
- POJ 1190 生日蛋糕
- poj 1190 生日蛋糕(dfs, 剪枝)
- POJ1190生日蛋糕[DFS 剪枝]
- POJ - 1190 生日蛋糕(dfs+剪枝)
- Poj 1190 生日蛋糕
- POJ1190 生日蛋糕(DFS剪枝)
- POJ 1190 生日蛋糕
- POJ 1190-生日蛋糕(dfs 深度搜索 优化减枝)
- POJ - 1190 生日蛋糕(深搜+神奇的剪枝)
- POJ1190 生日蛋糕 ACM解题报告(DFS回溯+剪枝)
- POJ 1190 生日蛋糕 估计最小答案dfs剪枝
- 1190 poj 生日蛋糕
- POJ 1190 生日蛋糕 搜索加剪枝
- POJ1190 生日蛋糕
- POJ 1190 生日蛋糕 搜索dfs
- poj 1190 生日蛋糕