【Link】:

【Description】



给你一个n*m的格子;

然后里面零零散散地放着葡萄

让你把它切成若干个小矩形方格

使得每个小矩形方格都恰好包含有一个葡萄.

要求切的长度最短;

问最短的切割距离;

【Solution】



记忆化搜索;

先枚举位点竖着切;

再枚举位点横着切

需要快速计算某个正方形内有多少个葡萄;

->前缀和;

每个dfs有5个参数;

x0,y0,x1,y1,cnt

左边4个参数,是当前切的这个矩形的左下角和右上角,以及这个矩形当前的葡萄个数;

输出dfs(1,1,n,m,k);



【NumberOf WA】



2



【Reviw】



一开始没有想到前缀和的统计方法。



【Code】

#include <bits/stdc++.h>
using namespace std; const int K = 400;
const int N = 20;
const int INF = 0x3f3f3f3f; int f[N+5][N+5][N+5][N+5];
int n,m,k;
int sum[N+5][N+5]; int cnt(int x0,int y0,int x1,int y1){
int num = 0;
num = sum[x1][y1]-sum[x1][y0-1]-sum[x0-1][y1]+sum[x0-1][y0-1];
return num;
} int dfs(int x0,int y0,int x1,int y1,int rest){
if (f[x0][y0][x1][y1]!=-1) return f[x0][y0][x1][y1];
if (rest==1) return f[x0][y0][x1][y1] = 0;
int mi = INF;
for (int i = y0;i <= y1-1;i++){
/*
left
x1 (x1,i) (x1,i+1) (x1,y1) x0,y0 (x0,i) (x0,i+1) (x0,y1)
*/
int numleft = cnt(x0,y0,x1,i),numright = cnt(x0,i+1,x1,y1);
if (numleft>=1 && numright>=1){
int temp1 = dfs(x0,y0,x1,i,numleft);
int temp2 = dfs(x0,i+1,x1,y1,numright);
mi = min(mi,temp1+temp2+x1-x0+1);
}
} for (int i = x0;i <= x1-1;i++){
/*
up
x1,y0 x1,y1 i+1,y0 i+1,y1
down
i,y0 i,y1 x0,y0 x0,y1
*/
int numup = cnt(i+1,y0,x1,y1),numdown = cnt(x0,y0,i,y1);
if (numup>=1 && numdown>=1){
int temp1 = dfs(i+1,y0,x1,y1,numup);
int temp2 = dfs(x0,y0,i,y1,numdown);
mi = min(mi,temp1+temp2+y1-y0+1);
}
}
return f[x0][y0][x1][y1] = mi;
} int main(){
//freopen("F:\\rush.txt","r",stdin);
int T = 0;
while (~scanf("%d%d%d",&n,&m,&k)){
T++;
memset(f,-1,sizeof f);
memset(sum,0,sizeof sum);
for (int i = 1;i <= k;i++){
int x,y;
scanf("%d%d",&x,&y);
sum[x][y]++;
}
for (int i = 1;i <= n;i++)
for (int j = 1;j <= m;j++)
sum[i][j] = sum[i][j] + sum[i-1][j] + sum[i][j-1] - sum[i-1][j-1]; printf("Case %d: %d\n",T,dfs(1,1,n,m,k));
}
return 0;
}

最新文章

  1. redis基础学习(不定期更新)
  2. [py]编码 Unicode utf-8
  3. 继承ActionSupport,返回INPUT的原因
  4. css层叠选择
  5. Web Navigation
  6. Code for the Homework2 改进
  7. Android_Intent_passValue(4)
  8. Gstreamer的一些基本概念与A/V同步分析
  9. vim多行增加缩进
  10. Ubuntu屏幕分辨率无1920 1080
  11. Android防止手动添加的本地库文件被NDK工具清理掉
  12. PowerShell ISE:Windows Server 2008 R2默认不安装
  13. js 判断 是否在当前页面 当前页面是否在前端
  14. 关于对springboot程序配置文件使用jasypt开源工具自定义加密
  15. 【转】#ifdef __cplusplus+extern &quot;C&quot;的用法
  16. C++ 常用算法
  17. 2019-03-08 RF 调试Zibee 数据
  18. java基础(十一) 枚举类型
  19. VCL 中的 Windows API 函数(2): ActivateKeyboardLayout
  20. VC++开机自动启动程序的几种方法 (转载)

热门文章

  1. BAPC2014 K&amp;amp;&amp;amp;HUNNU11591:Key to Knowledge(中途相遇法)
  2. 漫谈linux之文件IO篇(SSD写性能和机械硬盘差不多,读是4到10倍)
  3. [javase学习笔记]-6.7 封装
  4. Glide加载圆形图片第一次只显示默认图片
  5. 上传golang 版本SDK
  6. vue打包后显示空白正确处理方法
  7. session 存入 memcahce
  8. NodeJS学习笔记 (20)错误处理-error
  9. Java web application——Listener
  10. 新人 记录VUE中分页实现