HDU 2513 Cake slicing
2024-09-06 21:40:13
#include<bits/stdc++.h>
using namespace std;
int n,m,k;
int cherry[405],dp[405][405];
int solve(int l,int r)
{
//printf("%d,%d %d,%d\n",l/m,l%m,r/m,r%m);
int &ret=dp[l][r];
if(ret!=-1)return ret;
int nmin=30,nmax=-1,mmin=30,mmax=-1;
for(int i=1;i<=k;++i)
{
int ntmp=cherry[i]/m,mtmp=cherry[i]%m;
if(ntmp>=l/m&&ntmp<=r/m&&mtmp>=l%m&&mtmp<=r%m)nmin=min(nmin,ntmp),nmax=max(nmax,ntmp),mmin=min(mmin,mtmp),mmax=max(mmax,mtmp);
}
if(nmin==-1)ret=0;
if(nmin==nmax&&mmin==mmax)ret=0;
if(ret==0)return ret;
ret=0x3f3f3f3f;
for(int i=nmin;i<nmax;++i)ret=min(ret,solve(l,r-(r/m-i)*m)+solve(l+(i-l/m+1)*m,r)+(r%m-l%m+1));
for(int i=mmin;i<mmax;++i)ret=min(ret,solve(l,r-(r%m-i))+solve(l+(i-l%m+1),r)+(r/m-l/m+1));
return ret;
}
int main()
{
int Case=0;
while(~scanf("%d%d%d",&n,&m,&k))
{
memset(dp,-1,sizeof dp);
for(int i=1;i<=k;++i){int a,b;scanf("%d%d",&a,&b);cherry[i]=a*m-m+b-1;}
printf("Case %d: %d\n",++Case,solve(0,n*m-1));
}
}
最新文章
- http_build_query 的一个问题
- Blackfin DSP(八):1D DMA与音频处理模板
- 不用asp.net MVC,用WebForm照样可以实现MVC(请看最后一句话)
- poj2912(种类并查集+枚举)
- onclick事件分析
- C#实现文件下载
- MDK+硬件仿真器实现debugprintf()-stm32
- Mysql允许外网接入
- 在ctex环境下利用Metapost作图
- MFC对话框Style说明
- dplyr 数据操作 常用函数(5)
- 【WC2013】糖果公园
- Windows 2008 R2_NLB网络负载均衡(图文详解)(转)
- Oracle执行计划学习笔记
- less是什么?直接用css好还是less好
- Unity3D中利用Action实现自己的消息管理(订阅/发布)类
- Yii2 baisic版gii的使用和分页
- 洛谷P2900 [USACO08MAR]土地征用Land Acquisition(动态规划,斜率优化,决策单调性,线性规划,单调队列)
- VS2010 如何自动生成UML图
- [Android Pro] Swift 3.0多线程