枚举(分类讨论):BZOJ 1177: [Apio2009]Oil
1177: [Apio2009]Oil
Time Limit: 15 Sec Memory Limit: 162 MB
Submit: 1477 Solved: 589
[Submit]
Description
采
油区域
Siruseri政府决定将石油资源丰富的Navalur省的土地拍卖给私人承包商以建立油井。被拍卖的整块土地为一个矩形区域,被划分为M×N个小块。
Siruseri地质调查局有关于Navalur土地石油储量的估测数据。这些数据表示为M×N个非负整数,即对每一小块土地石油储量的估计值。
为了避免出现垄断,政府规定每一个承包商只能承包一个由K×K块相连的土地构成的正方形区域。
AoE石油联合公司由三个承包商组成,他们想选择三块互不相交的K×K的区域使得总的收益最大。 例如,假设石油储量的估计值如下: 1 1 1 1 1
1 1 1 1 1 1 1 1 1 1 1 1 1 1 8 8 8 8 8 1 1 1 1 8 8 8 8 8 1 1 1 1 8 8 8 8
8 1 1 1 1 1 1 1 8 8 8 1 1 1 1 1 1 1 1 8 8 8 1 1 1 1 1 1 9 9 9 1 1 1 1 1
1 9 9 9 如果K = 2, AoE公司可以承包的区域的石油储量总和为100, 如果K = 3,
AoE公司可以承包的区域的石油储量总和为208。 AoE公司雇佣你来写一个程序,帮助计算出他们可以承包的区域的石油储量之和的最大值。
Input
输入第一行包含三个整数M, N, K,其中M和N是矩形区域的行数和列数,K是每一个承包商承包的正方形的大小(边长的块数)。接下来M行,每行有N个非负整数表示这一行每一小块土地的石油储量的估计值
Output
输出只包含一个整数,表示AoE公司可以承包的区域的石油储量之和的最大值。
Sample Input
1 1 1 1 1 1 1 1 1
1 1 1 1 1 1 1 1 1
1 8 8 8 8 8 1 1 1
1 8 8 8 8 8 1 1 1
1 8 8 8 8 8 1 1 1
1 1 1 1 8 8 8 1 1
1 1 1 1 1 1 8 8 8
1 1 1 1 1 1 9 9 9
1 1 1 1 1 1 9 9 9
Sample Output
#include <iostream>
#include <cstring>
#include <cstdio>
using namespace std;
const int maxn=;
int Ul[maxn][maxn],Ur[maxn][maxn];
int Dl[maxn][maxn],Dr[maxn][maxn];
int a[maxn][maxn]; int sum(int x,int y,int k)
{
if(x<k||y<k)return ;
return a[x][y]-a[x-k][y]-a[x][y-k]+a[x-k][y-k];
} void Pre_Solve(int R,int C,int K)
{
for(int i=K;i<=R;i++)
for(int j=K;j<=C;j++){
int S=sum(i,j,K);
Ul[i][j]=S;
Ur[i][j-K+]=S;
Dl[i-K+][j]=S;
Dr[i-K+][j-K+]=S;
} for(int i=;i<=R;i++)
for(int j=;j<=C;j++)
Ul[i][j]=max(Ul[i][j],max(Ul[i-][j],Ul[i][j-])); for(int i=;i<=R;i++)
for(int j=C;j>=;j--)
Ur[i][j]=max(Ur[i][j],max(Ur[i-][j],Ur[i][j+])); for(int i=R;i>=;i--)
for(int j=;j<=C;j++)
Dl[i][j]=max(Dl[i][j],max(Dl[i+][j],Dl[i][j-])); for(int i=R;i>=;i--)
for(int j=C;j>=;j--)
Dr[i][j]=max(Dr[i][j],max(Dr[i+][j],Dr[i][j+]));
}
int ans=;
void Solve(int R,int C,int K)
{
for(int i=;i<=R;i++){
for(int j=;j<=C;j++){
ans=max(ans,Ul[i][C]+Dl[i+][j]+Dr[i+][j+]);
ans=max(ans,Ul[i][j]+Ur[i][j+]+Dr[i+][]);
ans=max(ans,Ul[i][j]+Dl[i+][j]+Dr[][j+]);
ans=max(ans,Ul[R][j]+Ur[i][j+]+Dr[i+][j+]);
}
}
for(int i=*K;i<R;i++){
int MaxS=;
for(int j=;j<=C;j++)
MaxS=max(MaxS,sum(i,j,K));
ans=max(ans,Ul[i-K][C]+MaxS+Dr[i+][]);
}
for(int j=*K;j<C;j++){
int MaxS=;
for(int i=;i<=R;i++)
MaxS=max(MaxS,sum(i,j,K));
ans=max(ans,Ul[R][j-K]+MaxS+Dr[][j+]);
}
}
int main()
{
#ifndef ONLINE_JUDGE
freopen("oil.in","r",stdin);
freopen("oil.out","w",stdout);
#endif
int R,C,K;
scanf("%d%d%d",&R,&C,&K);
for(int i=;i<=R;i++)
for(int j=;j<=C;j++){
scanf("%d",&a[i][j]);
a[i][j]+=a[i-][j]+a[i][j-]-a[i-][j-];
}
Pre_Solve(R,C,K);
Solve(R,C,K);
printf("%d\n",ans);
}
枚举(分类讨论):BZOJ 1177: [Apio2009]Oil的更多相关文章
- BZOJ 1177 [Apio2009]Oil(递推)
[题目链接] http://www.lydsy.com/JudgeOnline/problem.php?id=1177 [题目大意] 给出一个矩阵,从中选出3个k*k且不相交的矩阵,使得其总和最大 [ ...
- [BZOJ]1177: [Apio2009]Oil
题目大意:给出一个n*m的矩阵,选出3个不相交的k*k子矩阵,使得子矩阵中元素和最大.(k<=n,m<=1500) 思路:选出的子矩阵有3种情况:横着排三个.竖着排三个.三角状分布(其中有 ...
- BZOJ1177:[APIO2009]Oil(枚举,前缀和)
Description 采油区域 Siruseri政府决定将石油资源丰富的Navalur省的土地拍卖给私人承包商以建立油井.被拍卖的整块土地为一个矩形区域,被划分为M×N个小块. Siruseri地质 ...
- BZOJ 1067 降雨量(RMQ-ST+有毒的分类讨论)
1067: [SCOI2007]降雨量 Time Limit: 1 Sec Memory Limit: 162 MB Submit: 4399 Solved: 1182 [Submit][Stat ...
- bzoj 3779 重组病毒 好题 LCT+dfn序+线段树分类讨论
题目大意 1.将x到当前根路径上的所有点染成一种新的颜色: 2.将x到当前根路径上的所有点染成一种新的颜色,并且把这个点设为新的根: 3.查询以x为根的子树中所有点权值的平均值. 分析 原题codec ...
- Codeforces 460D Little Victor and Set --分类讨论+构造
题意:从区间[L,R]中选取不多于k个数,使这些数异或和尽量小,输出最小异或和以及选取的那些数. 解法:分类讨论. 设选取k个数. 1. k=4的时候如果区间长度>=4且L是偶数,那么可以构造四 ...
- [BZOJ1177][Apio2009]Oil
[BZOJ1177][Apio2009]Oil 试题描述 采油区域 Siruseri政府决定将石油资源丰富的Navalur省的土地拍卖给私人承包商以建立油井.被拍卖的整块土地为一个矩形区域,被划分为M ...
- Bzoj4558:分类讨论 计算几何 组合数学
国际惯例的题面: 这题让我爆肝啦......这种计数显然容斥,正好不含任何坏点的我们不会算,但是我们能算至少含零个坏点的,至少含一个坏点的,至少含两个坏点的......所以最终的答案就是(至少含零个坏 ...
- HDU 5203 Rikka with wood sticks 分类讨论
题目链接: hdu:http://acm.hdu.edu.cn/showproblem.php?pid=5203 bc(chinese):http://bestcoder.hdu.edu.cn/con ...
随机推荐
- vsftpd的主配置文件详解
anonymous_enable=YES 允许匿名用户登录#local_enable=YES 允许本地用户登录#write_enable=YES 允许写权限#local_umask=022 ##ano ...
- 【转】纯 CSS 实现高度与宽度成比例的效果
先来演示页面:Demo; 转的内容: 最近在做一个产品列表页面,布局如右图所示.页面中有若干个 item,其中每个 item 都向左浮动,并包含在自适应浏览器窗口宽度的父元素中. item 元素的 C ...
- 【转】 iOS开发UI篇—UIScrollView控件实现图片轮播
原文:http://www.cnblogs.com/wendingding/p/3763527.html iOS开发UI篇—UIScrollView控件实现图片轮播 一.实现效果 实现图片的自动轮播 ...
- hdoj 1686 kmp
题目: Sample Input 3 BAPC BAPC AZA AZAZAZA VERDI AVERDXIVYERDIAN Sample Output 1 3 0 代码: #in ...
- linux 部分命令简单使用介绍-ssh、scp、less、tail、find、grep(持续添加)
ssh 加密的网络协议,提供客户-服务模式. 登录 ssh username@ip ssh ip #不提供用 ...
- swfupload上传文件问题
如果你的框架用到了struts2的话 可能会造成request冲突 那么解决的办法就是把该request排除出去 不让struts2拦截
- phpcms V9 内容模型管理(转)
转自:http://www.cnblogs.com/Braveliu/p/5102627.html [1]理解模型 模型,系统知识的抽象表示.既然抽象了,那就得脑补一下.大家都是面向对象设计的专业人员 ...
- hold
嘿嘿,很久没写博客了.一懒一拖一浮躁就不行了. 果然烦心事太多,一直懒得编程.结果还是编程才能平复我啊! 明天那什么,别担心,平常心嘛! 还好,看了几部电影,不算没收获.自己有意思就看看电影,别瞎想啥 ...
- Javascript中的函数(Function)与对象(Object)的关系
今天我们来尝试理解Function和Object.因为这个里面有些人前期可能会搞糊涂.他们之间到底是什么关系.当然也不除外当初的我. 注意:官方定义: 在Javascript中,每一个函数实际上都是一 ...
- 极光推送 api ios参数问题
这是首个app项目,推送用的是极光推送jpush 由于用官方文档出现接收多条的问题,在网上找到一套封装好的,非常感觉这位开发者 //推送.指定人error_reporting(E_ALL^E_NOTI ...