一道不错的题,主要就是一个思路点,想到就行了,想不到就一直卡着。

看完题解之后发现挺简单,实际上自己挣扎半天也咩有想到。

一开始想类比成一维之后贪心,后来被同机房大佬 \(hack\) 掉了。

solution

首先二分答案,单调行很好证明,因为大矩形包含小矩形,现在的问题就是 \(check\) 函数

其实一个突破口就是只用三个矩形覆盖。

一维里面用几个矩形理论上都是通过输入给出的,所以一般的题的变量他通过常量给出来,可能就是突破口

对于题目中所有的点,肯定可以用一个大矩形套住,我们称之为“外接矩形”

思考一下可以发现,外接矩形的边上肯定有点,那么也一定有三个矩形的边(放边的原因是多放到外面肯定不如放到里面优

一个外接矩形有四条边,这就意味着,对于我们的三个矩形,肯定有一个要和两条边重合(也就是和一个角重合)

我们枚举是哪个角,之后把它范围内的点覆盖上,然后问题就变成了一个子问题(因为小于等于三个矩形都必须覆盖角,所以枚举角就可以了)。

然后经典的搜索和回溯就可以写完 \(check\) 函数。

code

(放着么美的代码有没有亮瞎您的眼?)

#include <cstring>
#include <algorithm>
#include <cstdio>
#define mp make_pair
#define R register int
#define int long
#define printf Ruusupuu = printf int Ruusupuu ; using namespace std ;
typedef long long L ;
typedef long double D ;
typedef unsigned long long G ;
typedef pair< int , int > PI ;
const int N = 2e4 + 10 ;
const int Inf = 1e9 + 10 ; inline int read(){
int w = 0 ; bool fg = 0 ; char ch = getchar() ;
while( ch < '0' || ch > '9' ) fg |= ( ch == '-' ) , ch = getchar() ;
while( ch >= '0' && ch <= '9' ) w = ( w << 1 ) + ( w << 3 ) + ( ch ^ '0' ) , ch = getchar() ;
return fg ? -w : w ;
} int n , mid , x [N] , y [N] ;
bool cvr [N] ;
int st [N] , top ; void sc(){
n = read() ;
for( R i = 1 ; i <= n ; i ++ ) x [i] = read() , y [i] = read() ;
} inline void rmcvr( int x ){ while( top > x ) cvr [st [top --]] = 0 ; } inline bool check( int now ){
if( top == n ) return 1 ;
if( now == 4 ) return 0 ; int l = Inf , r = -Inf , u = -Inf , d = Inf , bg = top ;
bool fg = 0 ; for( R i = 1 ; i <= n ; i ++ ) if( !cvr [i] ){
l = min( l , x [i] ) , r = max( r , x [i] ) ;
d = min( d , y [i] ) , u = max( u , y [i] ) ;
} // printf( "%ld %ld %ld %ld %ld\n" , now , l , r , u , d ) ; int ix , iy ; // left up
ix = l , iy = u ;
for( R i = 1 ; i <= n ; i ++ ) if( !cvr [i] ){
if( x [i] >= ix && x [i] <= ix + mid && y [i] >= iy - mid && y [i] <= iy ) cvr [i] = 1 , st [++ top] = i ;
} fg |= check( now + 1 ) ; rmcvr( bg ) ; if( fg ) return 1 ; // left down
ix = l , iy = d ;
for( R i = 1 ; i <= n ; i ++ ) if( !cvr [i] ){
if( x [i] >= ix && x [i] <= ix + mid && y [i] >= iy && y [i] <= iy + mid ) cvr [i] = 1 , st [++ top] = i ;
} fg |= check( now + 1 ) ; rmcvr( bg ) ; if( fg ) return 1 ; // right up
ix = r , iy = u ;
for( R i = 1 ; i <= n ; i ++ ) if( !cvr [i] ){
if( x [i] >= ix - mid && x [i] <= ix && y [i] >= iy - mid && y [i] <= iy ) cvr [i] = 1 , st [++ top] = i ;
} fg |= check( now + 1 ) ; rmcvr( bg ) ; if( fg ) return 1 ; // right down
ix = r , iy = d ;
for( R i = 1 ; i <= n ; i ++ ) if( !cvr [i] ){
if( x [i] >= ix - mid && x [i] <= ix && y [i] >= iy && y [i] <= iy + mid ) cvr [i] = 1 , st [++ top] = i ;
} fg |= check( now + 1 ) ; rmcvr( bg ) ; if( fg ) return 1 ; return 0 ;
} void work(){ int lside = 1 , rside = (int) 2e9 + 10 , ans ; while( lside <= rside ){
mid = ( 0ll + lside + rside ) >> 1 ;
if( check( 1 ) ) ans = mid , rside = mid - 1 ;
else lside = mid + 1 ;
} printf( "%ld\n" , ans ) ;
} signed main(){
sc() ;
work() ;
return 0 ;
}

题解—P2218 [HAOI2007]覆盖问题的更多相关文章

  1. 洛谷 P2218 [HAOI2007]覆盖问题 解题报告

    P2218 [HAOI2007]覆盖问题 题目描述 某人在山上种了\(N\)棵小树苗.冬天来了,温度急速下降,小树苗脆弱得不堪一击,于是树主人想用一些塑料薄膜把这些小树遮盖起来,经过一番长久的思考,他 ...

  2. P2218 [HAOI2007]覆盖问题

    传送门 首先可以想到二分答案,然后考虑判断 注意到所有点的外包矩形的四条边一定要被覆盖到,而正方形只有 $3$ 个,所以一定有一个正方形在角落 考虑爆搜,枚举正方形在当前外包矩形的那个角,然后对剩下的 ...

  3. BZOJ 1052: [HAOI2007]覆盖问题

    BZOJ 1052: [HAOI2007]覆盖问题 题意:给定平面上横纵坐标在-1e9~1e9内的20000个整数点的坐标,用三个大小相同边平行于坐标轴的正方形覆盖(在边界上的也算),问正方形的边长最 ...

  4. 【BZOJ1052】 [HAOI2007]覆盖问题

    BZOJ1052 [HAOI2007]覆盖问题 前言 小清新思维题. 最近肯定需要一些思维题挽救我这种碰到题目只会模板的菜鸡. 这题腾空出世? Solution 考虑一下我们二分答案怎么做? 首先转换 ...

  5. 【BZOJ 1052】 1052: [HAOI2007]覆盖问题 (乱搞)

    1052: [HAOI2007]覆盖问题 Description 某人在山上种了N棵小树苗.冬天来了,温度急速下降,小树苗脆弱得不堪一击,于是树主人想用一些塑料薄 膜把这些小树遮盖起来,经过一番长久的 ...

  6. [BZOJ1052][HAOI2007]覆盖问题 二分+贪心

    1052: [HAOI2007]覆盖问题 Time Limit: 10 Sec  Memory Limit: 162 MB Submit: 2053  Solved: 959 [Submit][Sta ...

  7. 【BZOJ】1052: [HAOI2007]覆盖问题(贪心)

    http://www.lydsy.com/JudgeOnline/problem.php?id=1052 首先膜拜题解orz,表示只能想到二分... 贪心就是每一次找到一个最小的能包围所有点的矩阵,然 ...

  8. bzoj1052 [HAOI2007]覆盖问题 - 贪心

    Description 某人在山上种了N棵小树苗.冬天来了,温度急速下降,小树苗脆弱得不堪一击,于是树主人想用一些塑料薄膜把这些小树遮盖起来,经过一番长久的思考,他决定用3个L*L的正方形塑料薄膜将小 ...

  9. 1052: [HAOI2007]覆盖问题 - BZOJ

    Description 某人在山上种了N棵小树苗.冬天来了,温度急速下降,小树苗脆弱得不堪一击,于是树主人想用一些塑料薄膜把这些小树遮盖起来,经过一番长久的思考,他决定用3个L*L的正方形塑料薄膜将小 ...

随机推荐

  1. SpEL表达式总结(转)

    前言 SpEL(Spring Expression Language),即Spring表达式语言,是比JSP的EL更强大的一种表达式语言.为什么要总结SpEL,因为它可以在运行时查询和操作数据,尤其是 ...

  2. Java | Map集合

    Map集合 在现实生活中,有非常多的东西,是和另外一种东西对应的,并且还是唯一的,比如:身份证号与个人,个人与手机,一夫一妻...等,这种关系就是对应关系,又叫做映射.Java为这种数据类型提供了专门 ...

  3. C语言:虚拟地址 和编译模式

    所谓虚拟地址空间,就是程序可以使用的虚拟地址的有效范围.虚拟地址和物理地址的映射关系由操作系统决定,相应地,虚拟地址空间的大小也由操作系统决定,但还会受到编译模式的影响.这节我们先讲解CPU,再讲解编 ...

  4. 8Java设计模式(持续更新)

    1.单例模式(Singleton pattern): 单例模式的实现方式是,一个类能返回对象的一个引用(永远是同一个)和一个获得该唯一实例的方法(必须是静态方法). 饿汉式: public class ...

  5. Python开发篇——构建虚拟Python开发环境(Conda+Poetry)

    前言 之前虽略有提及Python,但是没有实际地写点料.惭愧,惭愧,所以这次先起个头,讲讲如何构建虚拟Python开发环境.相信之前看过我博客的人可能会想:博主不会又要聊聊Docker吧?放心,不会. ...

  6. 前端基础js(四)

    一. js [1] html:用于显示页面 [2] css:用于描述页面的样式 [3] javaScript:用于描述页面的行为 二.js中三大部分内容 [1] 基本语法:函数.对象.事件类型(变量, ...

  7. 基于小熊派Hi3861鸿蒙开发的IoT物联网学习【四】

    一.互斥锁基本概念: 1.互斥锁又称互斥型信号量,是一种特殊的二值性信号量[二值型信号量可以理解为任务与中断间或者两个任务间的标志,该标志非"满"即"空"],用 ...

  8. 小鹤双拼win10一键恢复布局

    起因 一直用的小鹤双拼布局,最近重装系统又要重新配置,麻烦 尝试 查找对应注册表设置,找到以下路径包含相应配置 HKEY_CURRENT_USER\Software\Microsoft\InputMe ...

  9. 【用例】编写App测试用例的关注点

    编写App测试用例的关注点 如何做到测试用例的百分百覆盖一直是测试用例编写过程中的难点,首先在测试时我们经常会遇见一些常见的bug,那么我们可以在编写测试用例时考虑到这些点.    一:关于业务逻辑 ...

  10. SQL Server常用的几个存储过程

    1. sp_helptext 查看一些数据库对象的定义,比如存储过程.函数.试图等. 2. sp_who或者sp_who2 查看SQL Server数据库会话信息.比如是否被阻塞.