题面

先把题目意思讲一下吧:

给一个 \(n*n\) 的地图,每个格子有一个价格,找一个矩形区域,使其价格总和位于\([k,2k]\).

那么首先,可以想到,如果\(a[i][j]\)(格子的价格,下同)位于\([k,2k]\),直接输出就好.

而对于\(a[i][j]\)>\(2k\)的格子,它是不可能被选的,那么可以把它视为障碍物,

然后,剩下的格子的价格就一定小于\(k\).

那么,根据悬线法,

如果我们找到了一个极大子矩阵,且矩阵和(设为\(sum\))>=\(k\)(小于肯定是不行的),

如果\(sum\)<=\(2k\),就直接输出答案,

否则,判断第一行的和\(sum_{1}\),

若\(sum_{1}\)>=\(k\),那在第一行中肯定有解,

因为每个元素都小于\(k\)(前面说过了),

那么不存在一个格子能使矩阵和从大于\(2k\)一下变到小于\(k\),

因此只需要一个个删掉第一行的元素,直到符合要求即可.

而当\(sum_{1}\)<\(k\)时,

因为\(sum\)>\(2k\),

所以可以删掉第一行,再继续判断剩下的矩阵.

这一部分的实现方式:

inline void print_t(int x1,int y1,int x2,int y2)/*以(x1,y1)为左上角,(x2,y2)为右下角*/{
while(sum(x1,y1,x2,y2)/*矩阵和*/>m*2){
if(x1==x2) y2--;
else if(sum(x1,y1,x1,y2)>=m) x2=x1;
else x1++;
}
printf("%d %d %d %d\n",y1,x1,y2,x2);
exit(0);//终止程序
}

最后注意:找到答案后直接终止程序!

上完整代码:

#include<bits/stdc++.h>
#define ll long long
using namespace std; inline int read(){
int sum=0,f=1;char ch=getchar();
while(ch>'9' || ch<'0'){if(ch=='-')f=-1;ch=getchar();}
while(ch>='0' && ch<='9'){sum=sum*10+ch-'0';ch=getchar();}
return f*sum;
} int n,m;
ll a[2001][2001];//价格
ll s[2001][2001];//二维前缀和
int h[2001][2001]/*悬线*/,l[2001][2001]/*向左展开的位置*/,r[2001][2001]/*向右展开的位置*/; inline ll sum(int x1,int y1,int x2,int y2)/*矩阵和*/{
return s[x2][y2]+s[x1-1][y1-1]-s[x1-1][y2]-s[x2][y1-1];
} inline void print_t(int x1,int y1,int x2,int y2){
while(sum(x1,y1,x2,y2)>m*2){
if(x1==x2) y2--;
else if(sum(x1,y1,x1,y2)>=m) x2=x1;
else x1++;
}
printf("%d %d %d %d\n",y1,x1,y2,x2);
exit(0);
} int main(){
// freopen("kup.in","r",stdin);
// freopen("kup.out","w",stdout);
m=read();n=read();//m就是k,只是看上去顺眼一些而已[滑稽]
for(int i=1;i<=n;i++)
for(int j=1;j<=n;j++){
a[i][j]=read();
s[i][j]=s[i-1][j]+s[i][j-1]-s[i-1][j-1]+a[i][j];
if(a[i][j]<m||a[i][j]>2*m) continue;
printf("%d %d %d %d\n",j,i,j,i);
return 0;
}
for(int i=1;i<=n;i++) r[0][i]=n+1;
for(int i=1;i<=n;i++)
for(int j=1;j<=n;j++) h[i][j]= a[i][j]>2*m? 0:h[i-1][j]+1;
for(int i=1;i<=n;i++){
int ret=0;
for(int j=1;j<=n;j++){
if(h[i][j]) l[i][j]=max(l[i-1][j],ret);
else ret=j,l[i][j]=0;
}
ret=n+1;
for(int j=n;j;j--){
if(h[i][j]) r[i][j]=min(r[i-1][j],ret);
else ret=j,r[i][j]=n+1;
}
}
for(int i=1;i<=n;i++){
for(int j=1;j<=n;j++){
if(!h[i][j]) continue;
int x1=i-h[i][j]+1;
int y1=l[i][j]+1,y2=r[i][j]-1;
if(sum(x1,y1,i,y2)<m) continue;
print_t(x1,y1,i,y2);
}
}
puts("NIE");
return 0;
}

题解 【POI2008】KUP-Plot purchase的更多相关文章

  1. 1127: [POI2008]KUP

    1127: [POI2008]KUP https://lydsy.com/JudgeOnline/problem.php?id=1127 分析: 如果存在一个点大于等于k,小于等于2k的话,直接输出. ...

  2. [BZOJ1127][POI2008] KUP子矩阵

    Description 给一个n*n的地图,每个格子有一个价格,找一个矩形区域,使其价格总和位于[k,2k] Input 输入k n(n<2000)和一个n*n的地图 Output 输出矩形的左 ...

  3. bzoj1127: [POI2008]KUP

    Description 给一个n*n的地图,每个格子有一个价格,找一个矩形区域,使其价格总和位于[k,2k] Input 输入k n(n<2000)和一个n*n的地图 Output 输出矩形的左 ...

  4. bzoj1127[POI2008]KUP 悬线法

    Time Limit: 10 Sec  Memory Limit: 162 MBSec  Special JudgeSubmit: 485  Solved: 174[Submit][Status][D ...

  5. 解题:POI 2008 Plot purchase

    题面 原来看过然后没做,结果板板把这道题改了改考掉了,血亏=.= 首先看看有没有符合条件的点.如果没有开始寻找解,先把所有的大于$2*k$的点设为坏点,然后求最大子矩形,只要一个最大子矩形的权值和超过 ...

  6. [BZOJ] 1127: [POI2008]KUP

    似曾相识的感觉 考虑另一个判断问题,给定一个k,问这个k是否可行 存在矩形和\(sum>2k\),则该矩阵不对判定做出贡献 存在矩形和\(sum\in [k,2k]\),则我们找到了一个解 于是 ...

  7. bzoj 1127 [POI2008]KUP——思路(悬线法)

    题目:https://www.lydsy.com/JudgeOnline/problem.php?id=1127 大于2*K的视为不能选的“坏点”.有单个格子满足的就直接输出. 剩下的都是<K的 ...

  8. [POI2008]KUP

    Description 给一个\(n\times n\)的地图,每个格子有一个价格,找一个矩形区域,使其价格总和位于[k,2k] Input 输入k n(n<2000)和一个\(n\times ...

  9. 【BZOJ-1127】KUP 悬线法 + 贪心

    1127: [POI2008]KUP Time Limit: 10 Sec  Memory Limit: 162 MBSec  Special JudgeSubmit: 317  Solved: 11 ...

随机推荐

  1. Oracle-DQL 4- 多表查询

    多表查询: 1.笛卡尔积SELECT * FROM dept;--查询员工的信息和其所在部门的信息SELECT ename,job,dname,locFROM emp,dept; --集合A中的所有元 ...

  2. 洛谷P2622 关灯问题II (二进制枚举+bfs

    题目描述 现有n盏灯,以及m个按钮.每个按钮可以同时控制这n盏灯——按下了第i个按钮,对于所有的灯都有一个效果.按下i按钮对于第j盏灯,是下面3中效果之一:如果a[i][j]为1,那么当这盏灯开了的时 ...

  3. readlink、find-exec参数、file命令

    一.readlink:查看符号链接文件的内容 语法       readlink [选项] ...文件... 描述       打印符号链接或规范文件名的值 -f,--canonicalize     ...

  4. 并不对劲的复健训练-bzoj5253:loj2479:p4384:[2018多省联考]制胡窜

    题目大意 给出一个字符串\(S\),长度为\(n\)(\(n\leq 10^5\)),\(S[l:r]\)表示\(S_l,S_{l+1}...,S_r\)这个子串.有\(m\)(\(m\leq 3\t ...

  5. CVPR2019目标检测方法进展综述

    CVPR2019目标检测方法进展综述 置顶 2019年03月20日 14:14:04 SIGAI_csdn 阅读数 5869更多 分类专栏: 机器学习 人工智能 AI SIGAI   版权声明:本文为 ...

  6. 怎样理解Node对象接口

    dom中的节点都继承自Node接口, 也就是说, 所有的节点都具有Node接口所规定的属性和方法, 比如下面这个 <a> 标签, 它也继承了Node的所有属性和方法: 可以认为Node接口 ...

  7. 怎样使用 vue-cli ( Vue 脚手架 )

    vue-cli 是 Vue 官方出品的快速构建单页应用的脚手架, 相当于 React 官方出品的 create-react-app , 下面演示 vue-cli 的 最 基本用法: 1. 全局安装 v ...

  8. asp.net 4.Redirect重定向和文件图片上传

    1.Response.Redirect 如图所示: 1.用户点击修改按钮, 浏览器向服务器发送一个POST请求 http://localhost:6543/UpdateUser.ashx 2.服务器的 ...

  9. [转载]from __future__ import的用法

    一句话概况:这是为了在低版本python中使用高版本特性而引入的,最常用的就是print_function来实现在2.x中使用3.x中的print()命令,从而避免在切换版本时修改代码. https: ...

  10. 关于jar冲突的解决方向servlet-api

    1.可以考虑尽量往  java自带的jar  靠  比如说jdk-tools 2.如果用springboot项目  让其他jar 排除servlet-api的依赖 <dependency> ...