首页 > 其他分享 >[NOI1999] 生日蛋糕

[NOI1999] 生日蛋糕

时间:2023-03-28 21:15:52浏览次数:50  
标签:表面积 return NOI1999 int 样例 体积 ans 生日蛋糕

看题
洛谷传送门(食用更佳)

点击查看复杂的题目

题目背景

数据加强版 link

image

示例图:image

样例 #1

样例输入 #1

100
2

样例输出 #1

68

ok,开始愉快的AC之旅

第一步:预处理

定义 a,b数组,存储第i层最多能用的表面积和体积,便于优化


第二步:深度优先搜索

定义search函数,负责搜索

递归结束条件是:

1:蛋糕已完成,即层数p==m

2:体积超过了预定的值,或者表面积超过了之前存储的最小值ans


第三步:寻找优化方案!

这步尤为重要,没有合适的优化方案会导致超时

1:对于体积
在第一步已经完成了对最大体积的预处理,所以只需要用当前体积加上b[i-1],判断是否大于了规定体积n即可

即: if(v+b[p-1]>n) return ;//体积超出

2:对于表面积
如果 当前的表面积+余下的侧面积>当前最优值ans (这个应该很简单证明)

但是,如何实现呢???

于是就有了接下来的公式推理

设已经做了i层蛋糕,则还需做m-i层, 

Si’:为第i层蛋糕的侧面积,       
FSi:余下的侧面积

根据定义:
     V=π*R*R*H(在这里统一删掉π)
     则有:
      2Vi= 2R[i+1] * R[i+i] * H[i+1] + ...+ 2Rm * Rm * Hm
                      (每一层的体积之和)
         = R[i+1] *  S[i+1]’ + ...+ Rm * Sm’
         ≤ R[i+1] * (S[i+1]’+ ...+ Sm’)    放缩法
         = R[i+1]*FSi (剩余侧面积)
 所以:
               FSi ≥ 2Vi / Ri+1 

因此,剪枝条件变为了

2*(n-v)/r+s>=ans

于是前面预处理的a数组就可以去掉了

第三步完成

综合这三步编写代码,愉快的AC

#include<bits/stdc++.h>
using namespace std;
int a[21],b[21],m,n,ans;//a存储表面积,b存储体积 
void search(int v,int s,int p,int r,int h)//v为已用体积,s为已有表面积,p为剩余层数,r为半径,h为高 
{
    int i,j,hh;
    if (p==0)//蛋糕已完成
        {
        if (v==n&&s<ans)//判断是否符合要求并得到更优解
                ans=s;//更新最优解
        return ;
        }
        if(v+b[p-1]>n) return ;//体积超出 
        //if(s+a[p-1]>ans) return ;//表面积超出 
        if(2*(n-v)/r+s>=ans)  return; //重点:当前的表面积+余下的侧面积>当前最优值
        //剩余表面积FS>=2*V剩/r   
        //若FS+s>=ans 则不符合 
         for(i=r-1;i>=p;i--)//枚举上一层的半径
         {
            if(p==m) s=i*i;
            hh=min((n-v-b[p-1])/(i*i),h-1);
            for(j=hh;j>=p;j--)//枚举上一层的高
            search(v+i*i*j,s+2*i*j,p-1,i,j);
         }
}
int main()
{
      cin>>n>>m;
      ans=2147483647;
      a[0]=b[0]=0;
      for(int i=1;i<21;i++)
      {
       //a[i]=a[i-1]+2*i*i;//第i层使用的最大表面积 
        b[i]=b[i-1]+i*i*i;//第i层使用的最大体积 
      }
      search(0,0,m,n+1,n+1);
      if(ans==2147483647) cout<<'0';
      else cout<<ans;
      return 0;
}

标签:表面积,return,NOI1999,int,样例,体积,ans,生日蛋糕
From: https://www.cnblogs.com/momotrace/p/p1731.html

相关文章

  • 生日蛋糕
    #include<iostream>#include<math.h>usingnamespacestd;constintN=30,INF=1e9;intn,m;intminv[N],mins[N];//存当前层的最小体积和最小表面积intans=INF;......
  • P5752 [NOI1999] 棋盘分割题解
    本文来自我的洛谷博客。本题解力求使用清晰易懂的图片和文字,讲解最简洁的道理。请大家耐心地看完,注意要结合图片一起哦~~2022-8-24更改了格式与错别字2022-8-28更改......
  • 20230129 T1 生日蛋糕(birth)
    生日蛋糕(birth)伤心题。。。题意\(n\)个点的树,第\(i\)个点有点权\(1\lea_i\lem\)。对于每个\(i\)满足\(1\lei\lem\),求出连通块内点权最大值为\(i\)的个......
  • 牛客小白月赛64 C-Karashi的生日蛋糕(思维)
    https://ac.nowcoder.com/acm/contest/49244/C题目大意:Karashi决定将水果摆放成n圈,第i圈必须有i个水果。一共k个人,Karashi需要把蛋糕沿半径均分成k块,任意两块蛋糕包含......
  • AcWing168 生日蛋糕(剪枝)
    原题链接思路的话,就是暴搜加剪枝,中间有个放缩思路看这篇#include<bits/stdc++.h>#definepbpush_back#definefifirst#definesesecond#defineall(x)(x).begi......
  • 2022/8/19日测试 (内含Ticket Game,生日蛋糕,最优贸易,装满的油箱,道路游戏)
    TicketGame标签:思维--------------------------------------------------------------------------------------------------------Alice和Bob生活在Berland。Berland......