UESTC_神秘绑架案 CDOJ 881
神秘绑架案
Time Limit: 3000/1000MS (Java/Others) Memory Limit: 65535/65535KB (Java/Others)
冬马被方师傅绑架了!!!
一天,春希收到了一个信封,里面有一张印有8×8棋盘的纸,一个被加了密的U盘和一个便条。便条上写着:
冬马在我手上,如果你想救出冬马,U盘里就有我详细的地址,当然前提是你能解出密码!
你可以把这个棋盘分割成n块,每一次你可以从一棋盘上割下一块矩形,并让剩下的部分也是矩形,再将剩下的部分如此分割。
原棋盘每一格有一个分值,一块矩形的总分为其所含各格分值之和。你需要按上述方法将棋盘分成n块后,求出各矩形棋盘总分的均方差。我也不介意告诉你,所有均方差中的最小值就是U盘的密码,那么请挣扎吧!
平均数公式:
均方差公式:
------方师傅留
春希非常焦急的找到了你,希望你能找出这个最小值,救出冬马。
Input
第一行一个整数n,表示分割后的块数。(1<n<15)
第二行到第九行,每行八个小于100的非负整数,表示棋盘上相应格子的分值。
Output
一个数,表示求出的最小值。(四舍五入精确到小数点后三位)
Sample input and output
Sample Input | Sample Output |
---|---|
3 |
1.633 |
Source
#include <iostream>
#include <algorithm>
#include <cstdio>
#include <cstring>
#include <cmath>
using namespace std;
const int maxn = ;
int sum[maxn][maxn],n;
double f[][][],average= .;
bool arrive[][][]; inline int getr(int x)
{
return (x-)/ + ;
} inline int getc(int x)
{
return (x-) % + ;
} inline int getid(int x,int y)
{
return (x-)*+y;
} double getval(int left,int right)
{
int sumx = ;
int rst = getr(left) , red = getr(right) , cst = getc(left) , ced = getc(right);
for(int i = rst ; i <= red ; ++ i)
sumx += sum[i][ced] - sum[i][cst-];
return (double)(sumx - average)*(sumx - average);
} double dp(int left,int right,int times)
{
if (arrive[left][right][times])
return f[left][right][times];
double &ans = f[left][right][times] = 1e110;
arrive[left][right][times] = true;
int rst = getr(left) , red = getr(right) , cst = getc(left) , ced = getc(right);
int number = (red - rst + ) * (ced - cst + );
if (times > number)
return ans;
if (times == ) //无法继续切割
return ans = getval(left,right);
//竖着切
for(int i = cst + ; i <= ced ; ++ i)
{
int newleft = getid(rst,i);
int newright = getid(red,i-);
ans = min(ans,getval(left,newright)+dp(newleft,right,times-)); //拿右边继续切
ans = min(ans,getval(newleft,right)+dp(left,newright,times-)); //拿左边继续切
}
//横着切
for(int i = rst ; i < red ; ++ i)
{
for(int j = ; j <= times- ; ++ j)
{
int newleft = getid(i+,cst);
int newright = getid(i,ced);
ans = min(ans,getval(left,newright)+dp(newleft,right,times-)); //拿下面继续切
ans = min(ans,getval(newleft,right)+dp(left,newright,times-)); //拿上面继续切
}
}
return ans;
} int main(int argc,char *argv[])
{
memset(sum,,sizeof(sum));
memset(arrive,false,sizeof(arrive));
scanf("%d",&n);
for(int i = ; i <= ; ++ i)
for(int j = ; j <= ; ++ j)
{
int temp;
scanf("%d",&temp);
sum[i][j] = sum[i][j-] + temp;
average += (double)temp;
}
average /= n;
printf("%.3f\n",sqrt(dp(,,n) / n));
return ;
}
UESTC_神秘绑架案 CDOJ 881的更多相关文章
- UESTC 881 神秘绑架案 --二维DP
LRJ黑书上的例题. 化简均方差公式: 均值的平方一定,所以只需让矩形的总分的平方和最小即可. 定义:dp[k][x1][y1][x2][y2],以(x1,y1)为左上角坐标,(x2,y2)为右下角坐 ...
- UESTC_冬马党 CDOJ 882
冬马党 Time Limit: 3000/1000MS (Java/Others) Memory Limit: 65535/65535KB (Java/Others) Submit Statu ...
- 2014 UESTC暑前集训动态规划专题解题报告
A.爱管闲事 http://www.cnblogs.com/whatbeg/p/3762733.html B.轻音乐同好会 C.温泉旅馆 http://www.cnblogs.com/whatbeg/ ...
- java对xml文件的读取
<?xml version="1.0" encoding="UTF-8"?> <body> <names type="1 ...
- [No000056]你无法真正占有一个人,包括你的爱人,先生或太太、小孩,以及你自己....
从一出生,我们的双手就握的紧紧的,好像深知自己会失去什么 很多人迷信多子多孙才是福,老来才有依靠,但太多新闻告诉我们,很多人老了,子孙为了分家产,反而让他生不如死,死了还无法入土为安. 现实也告诉我们 ...
- 【海岛帝国系列赛】No.2 海岛帝国:“落汤鸡”市的黑帮危机
50200210海岛帝国:“落汤鸡”市的黑帮危机 [试题描述] 近几天,犯罪分子发现“药师傅”帝国的警力约等于0.(请见YSF的海岛帝国)于是开始猖狂了起来.他们选择了依山靠水(农村?)的“落汤鸡”市 ...
- UESTC_敢说就敢做 CDOJ 631
敢说就敢做 Time Limit: 3000/1000MS (Java/Others) Memory Limit: 65535/65535KB (Java/Others) Submit Sta ...
- UESTC_方老师的分身 II CDOJ 915
方老师的分身 II Time Limit: 10000/5000MS (Java/Others) Memory Limit: 65535/65535KB (Java/Others) Submi ...
- UESTC_方老师分身 I CDOJ 914
方老师分身 I Time Limit: 3000/1000MS (Java/Others) Memory Limit: 65535/65535KB (Java/Others) Submit S ...
随机推荐
- 自定义JSP标签实现语言国际化(类似struts text标签),并同时支持图片、JS文件国际化
源代码及样例下载地址: http://download.csdn.net/detail/u014569459/7169385 一.功能说明: 1. 支持语言国际化 2. 支持图片文件.JS文件国际化 ...
- 不得不看的JVM内存管理
作为一个任何完整的机器都会有内存管理这块组成结构.作为jvm也有自己的内存管理. 1.那么在java中哪些组件需要使用内存. a) Java堆 b) 线程:线程是在jvm运行 ...
- 【转】Linux系统性能分析命令
作为一名linux系统管理员,最主要的工作是优化系统配置,使应用在系统上以最优的状态运行,但是由于硬件问题.软件问题.网络环境等的复杂性和多变性,导致对系统的优化变得异常复杂,如何定位性能问题出在哪个 ...
- Linux usb子系统(一):子系统架构
一.USB协议基础知识 前序:USB概念概述 USB1.0版本速度1.5Mbps(低速USB) USB1.1版本速度12Mbps(全速USB) USB2.0版本速度480Mbps(高速USB). ...
- sleep()函数的的意义
===============WINDOWS平台下:====================== 关于VOID Sleep(DWORD dwMilliseconds);函数,许多人都觉得,它是告诉系统 ...
- blockUI
组件主页 主要使用到 blockUI 组件实现 将jquery和组件的JS下载到本地 然后直接就可以实现遮罩层功能 显示遮罩层:$.blockUI(); 隐藏遮罩层:$.unblockUI(); 该网 ...
- vue-router 快速入门
ue-router是Vue.js官方的路由插件,它和vue.js是深度集成的,适合用于构建单页面应用.vue的单页面应用是基于路由和组件的,路由用于设定访问路径,并将路径和组件映射起来.传统的页面应用 ...
- 继承之后的使用注意事项_ArrayStoreException
今天在看Core In Java第五章节时,看到一个很感兴趣的知识点,如下: 在Java中,子类数组的引用可以转换成超类数组的引用,而不需要采用强制转换.但是,在超类数组的引用添加超类类型引用对象之后 ...
- DotDensityRenderer
关键之处在于获取每个点所代表的的值 这里使用geodatabase类库中idatastatistic接口进行统计字段,再将结果传递给esrisysytem.istatisticsResult进行. 需 ...
- 在IIS Express中调试时无法读取配置文件
在IIS Express中调试代码时,如果出现“无法读取配置文件”的问题(如图),这种情况是IIS Express的“applicationhost.config”配置文件中的映射关系出了问题[ps: ...