#include <iostream>
#include 
<cmath>

using namespace std;

int data[10][10], n;
int dp[16][10][10][10][10];
int sum[10][10];

#define min(a,b) ( (a)<(b)?(a):(b) )
#define inf 1<<30

void get_sum(){
    memset( sum, 
0sizeof(sum) );
    
    
forint x= 1; x<= 8++x )
    
forint y= 1; y<= 8++y )
    sum[x][y]
= sum[x-1][y]+ sum[x][y-1]- sum[x-1][y-1]+ data[x][y];
}

int calc( int x1, int y1, int x2, int y2 ){
    
int t= sum[x2][y2]- sum[x2][y1-1]- sum[x1-1][y2]+ sum[x1-1][y1-1];
    
return t* t;
}

int run_dp( int level, int x1, int y1, int x2, int y2 ){
    
int tmp= inf;
    
    
if( dp[level][x1][y1][x2][y2]>= 0 ) return dp[level][x1][y1][x2][y2];
    
if( level== 1 ) {
        tmp
= calc( x1, y1, x2, y2 );
        dp[
1][x1][y1][x2][y2]= tmp;
        
return dp[1][x1][y1][x2][y2]; }

    
forint a= x1; a< x2; ++a ){
        tmp
= min( tmp, run_dp( level- 1, x1, y1, a, y2 )+ calc( a+ 1, y1, x2, y2 ) );
        tmp
= min( tmp, run_dp( level- 1, a+ 1, y1, x2, y2 )+ calc( x1, y1, a, y2 ) );
    }
    
forint a= y1; a< y2; ++a ){
        tmp
= min( tmp, run_dp( level- 1, x1, y1, x2, a )+ calc( x1, a+ 1, x2, y2 ) );
        tmp
= min( tmp, run_dp( level- 1, x1, a+ 1, x2, y2 )+ calc( x1, y1, x2, a ) );
    }
    dp[level][x1][y1][x2][y2]
= tmp;
    
return tmp;
}

int main()
{
    scanf(
"%d",&n );
    
    
double sum= 0;
    
forint i= 1; i<= 8++i )
    
forint j= 1; j<= 8++j ){
        scanf(
"%d"&data[i][j] );
        sum
+= data[i][j]; }
    
    get_sum(); sum
/= n ;
    memset( dp, 
-1sizeof(dp) );
    
double avg= (double)run_dp( n, 1188 );
    
double ans= sqrt( avg/ n- sum* sum );
    printf(
"%.3lf\n", ans );
    
    
return 0;
}
posted on 2009-05-22 20:07 Darren 阅读(309) 评论(1)  编辑 收藏 引用

评论:
# re: Pku 1191 棋盘分割 2009-05-22 20:09 | superlong
顶!  回复  更多评论
  

只有注册用户登录后才能发表评论。
网站导航: 博客园   IT新闻   BlogJava   知识库   博问   管理