[HAOI2007]分割矩阵 DP+推式子
发现最近好少写博客啊(其实是各种摆去了)
更一点吧
这道题要求最小化均方差,其实凭直觉来说就是要使每个块分的比较均匀一点,但是单单想到想到这些还是不够的,
首先f[i][j][k][l][t]表示以(i,j)为左上角,(k,l)为右下角,一共分割的t次的矩形的最小xx,
其中xx是某个与最小均方差挂钩的东西,
通常这种要求推式子的题目都要从小的情况推广到所有情况。
这道题也是一样的,
对于一个被分为x1和x2的矩形而言(分割了一次),用X表示平均数,
那么X=权值和/块数,
那么方差为:[(X - x1)^2 + (X - x2)^2] / 块数
对于固定的分割次数而言,块数是固定的,所以不管它,
那么我们就是要化简[(X - x1)^2 + (X - x2)^2]
原式=X^2 + x1^2 - 2 * X * x2 + X^2 + x2^2 - 2 * X * x2
=2(X ^ 2) + (x1^2 + x2^2) - 2 * X * (x1 + x2)
观察到x1+ x2就是权值和,是固定的,
而因为块数固定,X也是固定的,因此我们唯一可以改变的就是中间的平方部分,
所以我们的问题就转化为了一个矩形分割n-1次,求最小的平方和,
于是就可以直接dp了
f[i][j][k][l][t]表示以(i,j)为左上角,(k,l)为右下角,一共分割的t次的矩形的最小平方和,
同时为了满足dp性质(要求大状态先求小状态),左上角要倒着枚举,然后右下角正着枚举,
然后枚举分割线,枚举每块小矩形分割了多少次,最后计算一下即可
#include<bits/stdc++.h>
using namespace std;
#define R register int
#define AC 11
int ll,rr,n;
int f[AC][AC][AC][AC][AC];
int s[AC][AC],sum[AC][AC];
double ans,x;
/*以分两块(分别含有两小块)的合成为例
f[x]=((X - x1) ^ 2 + (X - x2) ^ 2)/2
对分子化简得:2 * X ^ 2 + x1 ^ 2 + x2 ^ 2 - 2 * X * (x1 + x2),
可以发现x1 + x2就是这一块的权值和,X为平均值,也就是权值和/块数,
也就是说对于任意一种分法,影响最终答案的只有x1 ^ 2 + x2 ^ 2这种,
所以只要最小化这个就可以了*/ inline void upmin(int &a,int b)
{
if(b < a) a=b;
} void pre()
{
memset(f,,sizeof(f));
scanf("%d%d%d",&ll,&rr,&n);
for(R i=;i<=ll;i++)
for(R j=;j<=rr;j++)
scanf("%d",&s[i][j]);
for(R i=;i<=ll;i++)
for(R j=;j<=rr;j++)
sum[i][j]=s[i][j] + sum[i-][j] + sum[i][j-] - sum[i-][j-];
for(R i=;i<=ll;i++)
for(R j=;j<=rr;j++)
for(R k=i;k<=ll;k++)
for(R l=j;l<=rr;l++)
{
int a=sum[k][l] - sum[i-][l] - sum[k][j-] + sum[i-][j-];
f[i][j][k][l][]=a * a;
}
/*for(R i=1;i<=ll;i++)
{
for(R j=1;j<=rr;j++)
{
printf("%d ",sum[i][j]);
}
printf("\n");
}*/
} void work()
{
for(R t=;t<n;t++)
for(R i=ll; i ;i--)//为了维护dp的条件,左上角应该要倒着枚举吧
for(R j=rr; j ;j--)//枚举左上角
{
for(R k=i;k<=ll;k++)
for(R l=j;l<=rr;l++)//枚举右上角
{
if(i == k && j == l) continue;
for(R p=j;p<l;p++)//枚举竖着的分界线
for(R tt=;tt<t;tt++)//原来的两块切割次数之和只能为t-1,因为现在切的就是第t次
upmin(f[i][j][k][l][t],f[i][j][k][p][tt] + f[i][p+][k][l][t - tt - ]);
for(R p=i;p<k;p++)//枚举横着的分界线
for(R tt=;tt<t;tt++)//枚举两块分别切了多少次,注意从0开始!!!
upmin(f[i][j][k][l][t],f[i][j][p][l][tt] + f[p+][j][k][l][t - tt - ]);
//printf("%d %d %d %d %d = %d\n",i,j,k,l,t,f[i][j][k][l][t]);
}
}
x=(double)sum[ll][rr] / (double)n;//获取平均值
ans=(double)(n * x * x) + (double)f[][][ll][rr][n-] - (double) * x * sum[ll][rr];
ans/=(double)n;
ans=sqrt(ans);
printf("%.2lf\n",ans);
} int main()
{
// freopen("in.in","r",stdin);
pre();
work();
// fclose(stdin);
return ;
}
[HAOI2007]分割矩阵 DP+推式子的更多相关文章
- LuoguP2217 [HAOI2007]分割矩阵 (DP + memorized search)
int n,m,tim; int mp[N][N], sum[N][N]; double ave,dp[N][N][N][N][N]; inline double DP(int a,int b,int ...
- bzoj千题计划186:bzoj1048: [HAOI2007]分割矩阵
http://www.lydsy.com/JudgeOnline/problem.php?id=1048 #include<cmath> #include<cstdio> #i ...
- 【BZOJ1048】 [HAOI2007]分割矩阵
[BZOJ1048][HAOI2007]分割矩阵 题面 bzoj 洛谷 题解 \(dp[a][b][c][d][num]\)表示将矩形\((a,b,c,d)\)分成\(num\)个的最小方差,然后转移 ...
- BZOJ 1048 [HAOI2007]分割矩阵
1048: [HAOI2007]分割矩阵 Time Limit: 10 Sec Memory Limit: 162 MBSubmit: 623 Solved: 449[Submit][Status ...
- 洛谷P2217 [HAOI2007]分割矩阵
P2217 [HAOI2007]分割矩阵 题目描述 将一个a*b的数字矩阵进行如下分割:将原矩阵沿某一条直线分割成两个矩阵,再将生成的两个矩阵继续如此分割(当然也可以只分割其中的一个),这样分割了(n ...
- [BZOJ 1048] [HAOI2007] 分割矩阵 【记忆化搜索】
题目链接:BZOJ - 1048 题目分析 感觉这种分割矩阵之类的题目很多都是这样子的. 方差中用到的平均数是可以直接算出来的,然后记忆化搜索 Solve(x, xx, y, yy, k) 表示横坐标 ...
- BZOJ1048:[HAOI2007]分割矩阵(记忆化搜索DP)
Description 将一个a*b的数字矩阵进行如下分割:将原矩阵沿某一条直线分割成两个矩阵,再将生成的两个矩阵继续如此分割(当然也可以只分割其中的一个), 这样分割了(n-1)次后,原矩阵被分割成 ...
- 【题解】HAOI2007分割矩阵
水题盛宴啦啦啦……做起来真的极其舒服,比某些毒瘤题好太多了…… 数据范围极小 --> 状压 / 搜索 / 高维度dp:观察要求的均方差,开始考虑是不是能够换一下式子.我们用\(a_{x}\)来表 ...
- 【BZOJ】1048: [HAOI2007]分割矩阵
http://www.lydsy.com/JudgeOnline/problem.php?id=1048 题意:给出一个a×b(a,b<=10)的矩阵,带一个<=100的权值,现在要切割n ...
随机推荐
- Java图片转字符
很久都没有更新博客了,昨天下午一个朋友问我能不能将一张图片转换成字符画,然后我想我这个朋友不知道,也许有的朋友以不知道,我就简单的分享一下 package com.xsl.zhuanhuan; imp ...
- rn打包分析
rn打包原来是packager,后来独立出一个专门的打包工具metro,构建工具的大体思路跟前端构建工具差不多,都会有一个启动文件,然后根据模块依赖关系把对应文件找到. 开发中打包 在开发中打包,我们 ...
- .net backend return json string , used by frontend
伪代码: backend: public string GetJson() { var lst = xxxLst; var obj = Json(lst);return new JavaScriptS ...
- InnoDB意向锁和插入意向锁
Preface Last night one buddy in tech wechat group asked "what's intention locks of Inno ...
- Adobe Photoshop CC2018最新教程+某宝店铺装修教程
PS免费教程,ps淘宝店铺装修教程.该资源为本人从某商网站重金买来,现免费分享给大家,下载地址:百度网盘,https://pan.baidu.com/s/127PjFbGwVVUVce1litHFsw
- WebDriver--定位元素的8种方式
在UI层面的自动化测试开发中,元素的定位与操作是基础,也是经常遇到的困难所在.webdriver提供了8种定位: 1. id定位:find_element_by_id("id值") ...
- hdu1789 Doing Homework again(贪心+排序)
Doing Homework again Time Limit: 1000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Oth ...
- 获取App的PackageName包名和LauncherActivity启动页
第一种情况: 查看手机里面已经安装的App: 用数据线连接手机, 打开开发者模式, 并赋予相关权限: 1. 清除日志: adb logcat -c 2. 启动日志: adb logcat Activi ...
- 【springmvc+mybatis项目实战】杰信商贸-4.maven依赖+PO对+映射文件
上一篇我们附件的增删改查功能全部完成.但是我们的附件有一个字段叫做“类型”(ctype),这里我们要使用数据字典,所以对于这一块我们要进行修改. 首先介绍一下数据字典 数据字典它是一个通用结构,跟业务 ...
- Pandas基础教程
pandas教程 更多地可以 参考教程 安装 pip install pandas pandas的类excel操作,超级方便: import pandas as pd dates = pd.date_ ...