P1436 棋盘分割

题目描述

将一个8*8的棋盘进行如下分割:将原棋盘割下一块矩形棋盘并使剩下部分也是矩形,再将剩下的两部分中的任意一块继续如此分割,这样割了(n-1)次后,连同最后剩下的矩形棋盘共有n块矩形棋盘。(每次切割都只能沿着棋盘格子的边进行)

原棋盘上每一格有一个分值,一块矩形棋盘的总分为其所含各格分值之和。现在需要把棋盘按上述规则分割成n块矩形棋盘,并使各矩形棋盘总分的平方和最小。

请编程对给出的棋盘及n,求出平方和的最小值。

输入输出格式

输入格式:

第1行为一个整数n(1 < n < 15)。

第2行至第9行每行为8个小于100的非负整数,表示棋盘上相应格子的分值。每行相邻两数之间用一个空格分隔。

输出格式:

仅一个数,为平方和。


大力区间DP

\(dp[i][j][k][l][dep]\)表示左上角坐标为\((i,j)\),右下角为\((k,l)\)的矩形在处于第\(dep\)次切割时产生的答案

我打的是记忆化搜索


Code:

#include <cstdio>
#include <cstring>
const int inf=0x3f3f3f3f;
int min(int x,int y){return x<y?x:y;}
int n,score[9][9],f[9][9],dp[9][9][9][9][16];//左上角,右下角
int get(int i,int j,int k,int l)
{
return f[k][l]-f[k][j-1]-f[i-1][l]+f[i-1][j-1];
}
int dfs(int x1,int y1,int x2,int y2,int dep)
{
if(~dp[x1][y1][x2][y2][dep]) return dp[x1][y1][x2][y2][dep];
dp[x1][y1][x2][y2][dep]=inf;
for(int i=x1;i<x2;i++)
{
dp[x1][y1][x2][y2][dep]=min(dp[x1][y1][x2][y2][dep],dfs(x1,y1,i,y2,dep+1)+get(i+1,y1,x2,y2)*get(i+1,y1,x2,y2));
dp[x1][y1][x2][y2][dep]=min(dp[x1][y1][x2][y2][dep],dfs(i+1,y1,x2,y2,dep+1)+get(x1,y1,i,y2)*get(x1,y1,i,y2));
}
for(int i=y1;i<y2;i++)
{
dp[x1][y1][x2][y2][dep]=min(dp[x1][y1][x2][y2][dep],dfs(x1,y1,x2,i,dep+1)+get(x1,i+1,x2,y2)*get(x1,i+1,x2,y2));
dp[x1][y1][x2][y2][dep]=min(dp[x1][y1][x2][y2][dep],dfs(x1,i+1,x2,y2,dep+1)+get(x1,y1,x2,i)*get(x1,y1,x2,i));
}
return dp[x1][y1][x2][y2][dep];
}
int main()
{
scanf("%d",&n);
memset(dp,-1,sizeof(dp));
for(int i=1;i<=8;i++)
for(int j=1;j<=8;j++)
{
scanf("%d",&score[i][j]);
f[i][j]=f[i-1][j]+f[i][j-1]-f[i-1][j-1]+score[i][j];
}
for(int i=1;i<=8;i++)
for(int j=1;j<=8;j++)
for(int k=1;k<=8;k++)
for(int l=1;l<=8;l++)
dp[i][j][k][l][n]=get(i,j,k,l)*get(i,j,k,l);
printf("%d\n",dfs(1,1,8,8,1));
return 0;
}

2018.7.11

最新文章

  1. 《从零开始做一个MEAN全栈项目》(4)
  2. Swift编程语言(中文版)官方手册翻译(进度8.8%)
  3. 电路相关知识--读&lt;&lt;继电器是如何成为CPU的&gt;&gt;
  4. JS类的封装及实现代码
  5. VS2005 “无法在证书存储区中找到清单签名证书”错误的解决方法
  6. Codeforces Round #379 (Div. 2) A. Anton and Danik 水题
  7. windows下gvim与gcc的一键环境的搭建
  8. char,wchar_t,WCHAR,TCHAR,ACHAR的区别----LPCTSTR
  9. 转: 在.NET中操作数字证书
  10. ubuntu中安装eclipse
  11. SharePoint webpart中悬浮窗口的webconfig路径
  12. 【Android】又一个Gank客户端来啦
  13. 电子称DIY(贴应变片+写代码)
  14. J2EE进阶(十二)SSH框架整合常见问题汇总(三)
  15. Analysis of Web.xml in Hello1 project
  16. !!常用HTML5代码
  17. Excel宏录制、数据透视表、合并多个页签
  18. codeforces-1102e
  19. Lua和C++交互 学习记录之四:全局table交互
  20. ansible管理windows (发送文件)

热门文章

  1. route命令详情
  2. OGG FOR BIGDATA 安装(修正)
  3. Java第二次实验20135204
  4. 作业45//Calculator::3.0
  5. 【CSAPP笔记】13. 链接
  6. Alpha阶段综合报告
  7. angularJS1笔记-(11)-自定义指令(transclude/priority/terminal)
  8. 预则立&amp;&amp;他山之石--团队计划、访谈优秀前辈
  9. 软工网络15团队作业8——Beta阶段敏捷冲刺(Day4)
  10. svm小问题