发现最近好少写博客啊(其实是各种摆去了)

更一点吧

这道题要求最小化均方差,其实凭直觉来说就是要使每个块分的比较均匀一点,但是单单想到想到这些还是不够的,

首先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+推式子的更多相关文章

  1. 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 ...

  2. bzoj千题计划186:bzoj1048: [HAOI2007]分割矩阵

    http://www.lydsy.com/JudgeOnline/problem.php?id=1048 #include<cmath> #include<cstdio> #i ...

  3. 【BZOJ1048】 [HAOI2007]分割矩阵

    [BZOJ1048][HAOI2007]分割矩阵 题面 bzoj 洛谷 题解 \(dp[a][b][c][d][num]\)表示将矩形\((a,b,c,d)\)分成\(num\)个的最小方差,然后转移 ...

  4. BZOJ 1048 [HAOI2007]分割矩阵

    1048: [HAOI2007]分割矩阵 Time Limit: 10 Sec  Memory Limit: 162 MBSubmit: 623  Solved: 449[Submit][Status ...

  5. 洛谷P2217 [HAOI2007]分割矩阵

    P2217 [HAOI2007]分割矩阵 题目描述 将一个a*b的数字矩阵进行如下分割:将原矩阵沿某一条直线分割成两个矩阵,再将生成的两个矩阵继续如此分割(当然也可以只分割其中的一个),这样分割了(n ...

  6. [BZOJ 1048] [HAOI2007] 分割矩阵 【记忆化搜索】

    题目链接:BZOJ - 1048 题目分析 感觉这种分割矩阵之类的题目很多都是这样子的. 方差中用到的平均数是可以直接算出来的,然后记忆化搜索 Solve(x, xx, y, yy, k) 表示横坐标 ...

  7. BZOJ1048:[HAOI2007]分割矩阵(记忆化搜索DP)

    Description 将一个a*b的数字矩阵进行如下分割:将原矩阵沿某一条直线分割成两个矩阵,再将生成的两个矩阵继续如此分割(当然也可以只分割其中的一个), 这样分割了(n-1)次后,原矩阵被分割成 ...

  8. 【题解】HAOI2007分割矩阵

    水题盛宴啦啦啦……做起来真的极其舒服,比某些毒瘤题好太多了…… 数据范围极小 --> 状压 / 搜索 / 高维度dp:观察要求的均方差,开始考虑是不是能够换一下式子.我们用\(a_{x}\)来表 ...

  9. 【BZOJ】1048: [HAOI2007]分割矩阵

    http://www.lydsy.com/JudgeOnline/problem.php?id=1048 题意:给出一个a×b(a,b<=10)的矩阵,带一个<=100的权值,现在要切割n ...

随机推荐

  1. MySQL高级-索引优化

    索引失效 1. 2.最佳左前缀法则 4. 8. 使用覆盖索引解决这个问题. 二.索引优化 1.ORDER BY 子句,尽量使用Index方式排序,避免使用FileSort方式排序 MySQL支持两种方 ...

  2. Spring Cloud(十一):服务网关 Zuul(过滤器)【Finchley 版】

    Spring Cloud(十一):服务网关 Zuul(过滤器)[Finchley 版]  发表于 2018-04-23 |  更新于 2018-05-07 |  在上篇文章中我们了解了 Spring ...

  3. 本地矩阵(Local Matrix)

    本地矩阵具有整型的行.列索引值和双精度浮点型的元素值,它存储在单机上.MLlib支持稠密矩阵DenseMatrix和稀疏矩阵Sparse Matrix两种本地矩阵,稠密矩阵将所有元素的值存储在一个列优 ...

  4. OpenMPI源码剖析3:try_kill_peers 和 ompi_rte_abort 函数

    接着上一篇的疑问,我们说道,会执行 try_kill_peers 函数,它的函数定义在 ompi_mpi_abort.c 下: // 这里注释也说到了,主要是杀死在同一个communicator的进程 ...

  5. Python实现个性化推荐二

    基于内容的推荐引擎是怎么工作的 基于内容的推荐系统,正如你的朋友和同事预期的那样,会考虑商品的实际属性,比如商品描述,商品名,价格等等.如果你以前从没接触过推荐系统,然后现在有人拿枪指着你的头,强迫你 ...

  6. Python决定一个变量时局部的,还是全局的,是在编译期

    Python中的变量名是在编译时就解析好的,换句话说,在编译时(也就是在交互控制台输入代码是或者import文件时),Python就已经决定一个变量应该是局部变量,还是全局变量.来看下面的例子: &g ...

  7. 《剑指Offer》题十一~题二十

    十一.旋转数组的最小数字 题目:把一个数组最开始的若干个元素搬到数组的末尾,我们称之为数组的旋转.输入一个递增排序的数组的一个旋转,输出旋转数组的最小元素.例如,数组{3, 4, 5, 1, 2}为{ ...

  8. 2d命令行小游戏源码

    using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.T ...

  9. Gym - 100851F Froggy Ford kruskal

    题目链接: http://acm.hust.edu.cn/vjudge/problem/307216 Froggy Ford Time Limit: 3000MS 题意 青蛙过河,河中有若干个石头,现 ...

  10. TCP系列27—窗口管理&流控—1、概述

    在前面的内容中我们依次介绍了TCP的连接建立和终止过程和TCP的各种重传方式.接着我们在这部分首先关注交互式应用TCP连接相关内容如延迟ACK.Nagle算法.Cork算法等,接着我们引入流控机制(f ...