zoukankan      html  css  js  c++  java
  • P2217 [HAOI2007]分割矩阵

    传送门

    首先均方差公式: $sigma = sqrt{sum_{i}^{K}frac{(sum[i]-ar{sum})^2}{n}}$

    其中 $ar{sum}$ 为小矩阵的平均值,显然 $ar{sum}=frac{sum_{i}^{K}sum[i]}{K}$

    所以就是要最小化 $(sum[i]-ar{sum})^2$

    看到数据这么小,搜就完事了

    直接 $dfs(xa,ya,xb,yb,k)$ 表示以 $(xa,ya)$ 为左下角,$(xb,yb)$ 为右上角的子矩阵内,切 $k$ 次后的 $(sum[i]-ar{sum})^2$ 最小值

    然后发现重复的状态很多,所以记忆化一下,稳了

    #include<iostream>
    #include<cstdio>
    #include<algorithm>
    #include<cstring>
    #include<cmath>
    using namespace std;
    typedef long long ll;
    typedef double db;
    inline int read()
    {
        int x=0,f=1; char ch=getchar();
        while(ch<'0'||ch>'9') { if(ch=='-') f=-1; ch=getchar(); }
        while(ch>='0'&&ch<='9') { x=(x<<1)+(x<<3)+(ch^48); ch=getchar(); }
        return x*f;
    }
    const int N=11,INF=1e9;
    int n,m,K,sum[N][N];
    db f[N][N][N][N][N],P;
    bool vis[N][N][N][N][N];
    inline db calc(int xa,int ya,int xb,int yb) { return sum[xb][yb]-sum[xa-1][yb]-sum[xb][ya-1]+sum[xa-1][ya-1]; }
    db dfs(int xa,int ya,int xb,int yb,int k)
    {
        if(xb-xa+yb-ya<k) return INF;
        db &T=f[xa][ya][xb][yb][k];
        if(vis[xa][ya][xb][yb][k]) return T;
        vis[xa][ya][xb][yb][k]=1; T=INF;
        if(!k) { T=(calc(xa,ya,xb,yb)-P)*(calc(xa,ya,xb,yb)-P); return T; }
        for(int i=0;i<k;i++)
            for(int j=xa;j<xb;j++)
                T=min(T, dfs(xa,ya,j,yb,i)+dfs(j+1,ya,xb,yb,k-i-1) );
        for(int i=0;i<k;i++)
            for(int j=ya;j<yb;j++)
                T=min(T, dfs(xa,ya,xb,j,i)+dfs(xa,j+1,xb,yb,k-i-1) );
        return T;
    }
    int main()
    {
        n=read(),m=read(),K=read();
        for(int i=1;i<=n;i++)
            for(int j=1;j<=m;j++) sum[i][j]=sum[i-1][j]+sum[i][j-1]-sum[i-1][j-1]+read();
        P=1.0*sum[n][m]/K;
        printf("%.2lf
    ",sqrt( dfs(1,1,n,m,K-1)/K ));
        return 0;
    }
  • 相关阅读:
    Centos6.5安装Oracle11.2.0.4 RAC(完整版)
    VMware搭建Oracle 11g RAC测试环境 For Linux
    Linux CentOS命令行界面字体重复问题解决记录
    SSH公钥认证(码云)
    Git 上传本地仓库到码云
    Git 相关工具及教程地址
    jdk8 新特性stream().map()
    PowerDesigner 使用记录
    IDEA 中.properties文件中文自动转Unicode编码及乱码问题
    idea在Maven Projects中显示灰色的解决办法
  • 原文地址:https://www.cnblogs.com/LLTYYC/p/11444523.html
Copyright © 2011-2022 走看看