热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

P1731生日蛋糕减枝

这道题可以通过一般的搜索找到思路,但是很显然会超时所以需要优化其中需要三重优化:第一重是如果已用面积+最小面积仍然超过最优答案就返回第二重是如果已用体积+最小体积仍然超过

//这道题可以通过一般的搜索找到思路,但是很显然会超时所以需要优化

//其中需要三重优化:第一重是如果已用面积+最小面积仍然超过最优答案就返回

//第二重是如果已用体积+最小体积仍然超过要求体积就返回

//第三重剪枝是假设剩余所有的体积都用来做下一层那么此时下一层的体积是最大,而半径会最大,从而表面积最小

#include
#include
using namespace std;
int m,n,Minv[21],Mins[21],Best;
void Read()
{  int i;
   cin>>n>>m;
   Minv[0]=0;
   for(i=1;i<=m;i++)
   {
        Mins[i]=Mins[i-1]+2*i*i; 
        Minv[i]=Minv[i-1]+i*i*i;  //初始化最小体积和
   } 
}
void search(int floor,int r,int h,int s,int v)//对每层蛋糕进行搜索,已经用的面积和体积 
{  
   int i,j,Maxv;
   if(floor==0&&v==0){if(sreturn;}
   if(s+Mins[floor]>=Best)return;//剪枝1,最优性剪枝
   if(vfloor])return;//剪枝2,根据下界进行可行性剪枝
   Maxv=0;
   for(i=floor;i>=1;i--)
       Maxv+=(r-i)*(r-i)*(h-i);//最大方式做蛋糕
   if(Maxvreturn; //剪枝3,根据上界进行可行性剪枝
   for(i=r-1;i>=floor;i--) //枚举floor层蛋糕的半径
      for(j=h-1;j>=floor;j--) //枚举floor层蛋糕的高度
         search(floor-1,i,j,s+2*i*j,v-i*i*j);
}
int main()
{  
   int r,h,s,v;
   Read();
   Best=0x7fffffff/2;
   for(r=m;r<=sqrt(n);r++)//枚举最底层蛋糕的半径
      for(h=n/(r*r);h>=m;h--)//枚举最底层蛋糕的对应高度
      {  
         s=r*r+2*r*h;
         v=n-r*r*h;
         search(m-1,r,h,s,v);
      }   
   cout<

推荐阅读
  • 本文探讨了在C++中如何有效地清空输入缓冲区,确保程序只处理最近的输入并丢弃多余的输入。我们将介绍一种不阻塞的方法,并提供一个具体的实现方案。 ... [详细]
  • 本文介绍了几种不同的编程方法来计算从1到n的自然数之和,包括循环、递归、面向对象以及模板元编程等技术。每种方法都有其特点和适用场景。 ... [详细]
  • 本次考试于2016年10月25日上午7:50至11:15举行,主要涉及数学专题,特别是斐波那契数列的性质及其在编程中的应用。本文将详细解析考试中的题目,并提供解题思路和代码实现。 ... [详细]
  • 本文探讨了将类成员属性设置为私有的重要性,并通过具体代码示例展示了如何实现对这些属性的有效控制。私有成员属性有助于增强数据的安全性和完整性,确保只有经过验证的数据才能被修改。 ... [详细]
  • 作为一名专业的Web前端工程师,掌握HTML和CSS的命名规范是至关重要的。良好的命名习惯不仅有助于提高代码的可读性和维护性,还能促进团队协作。本文将详细介绍Web前端开发中常用的HTML和CSS命名规范,并提供实用的建议。 ... [详细]
  • 深入理解Redis的数据结构与对象系统
    本文详细探讨了Redis中的数据结构和对象系统的实现,包括字符串、列表、集合、哈希表和有序集合等五种核心对象类型,以及它们所使用的底层数据结构。通过分析源码和相关文献,帮助读者更好地理解Redis的设计原理。 ... [详细]
  • 本文深入探讨了POJ2762问题,旨在通过强连通分量缩点和单向连通性的判断方法,解决有向图中任意两点之间的可达性问题。文章详细介绍了算法原理、实现步骤,并附带完整的代码示例。 ... [详细]
  • 哈密顿回路问题旨在寻找一个简单回路,该回路包含图中的每个顶点。本文将介绍如何判断给定的路径是否构成哈密顿回路。 ... [详细]
  • 本题探讨了在一个有向图中,如何根据特定规则将城市划分为若干个区域,使得每个区域内的城市之间能够相互到达,并且划分的区域数量最少。题目提供了时间限制和内存限制,要求在给定的城市和道路信息下,计算出最少需要划分的区域数量。 ... [详细]
  • 本文探讨了如何在iOS开发环境中,特别是在Xcode 6.1中,设置和应用自定义文本样式。我们将详细介绍实现方法,并提供一些实用的技巧。 ... [详细]
  • 本文详细介绍了Java中的输入输出(IO)流,包括其基本概念、分类及应用。IO流是用于在程序和外部资源之间传输数据的一套API。根据数据流动的方向,可以分为输入流(从外部流向程序)和输出流(从程序流向外部)。此外,还涵盖了字节流和字符流的区别及其具体实现。 ... [详细]
  • 嵌入式系统开发:外部中断详解
    本文深入探讨了外部中断的原理和应用,详细介绍了如何配置和使用外部中断,包括硬件设计、编程实现及调试技巧。 ... [详细]
  • 不确定性|放入_华为机试题 HJ9提取不重复的整数
    不确定性|放入_华为机试题 HJ9提取不重复的整数 ... [详细]
  • 本文介绍了一种从与src同级的config目录中读取属性文件内容的方法。通过使用Java的Properties类和InputStream,可以轻松加载并获取指定键对应的值。 ... [详细]
  • C语言基础入门:7个经典小程序助你快速掌握编程技巧
    本文精选了7个经典的C语言小程序,旨在帮助初学者快速掌握编程基础。通过这些程序的实践,你将更深入地理解C语言的核心概念和语法结构。 ... [详细]
author-avatar
黑旦儿
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有