zoukankan      html  css  js  c++  java
  • 快乐的一天从AC开始 | 20210728 | P2218

    题目链接

    工作难度逐渐飙升,我还只是个3周经验的菜鸟啊

    这周过完之后,来公司也满一个月了,周五团建可以提早下班,聚餐还挺舒服的,就是吃完饭还有卡丁车,对于我不太友好

    心路历程

    观察

    思路

    首先,看到求满足条件的最小值可以想到二分。

    然后,对于一个二位点集,求出覆盖这些点且边长最小的正方形,这个正方形是唯一的。此时有正方形的边上必定有点,所以3个小正方形种必定都有边和大正方形的边重合,因为每条边上的点都需要被一个小正方形覆盖。

    然后,因为正方形有4条边,所以必定有一个小正方形有两条边和大正方形重合,即至少有一个小正方形,它的角和大正方形的角重合。

    然后,可以先枚举第一个小正方形覆盖哪个角,把已经覆盖的点去掉。

    现在,要用两个正方形去覆盖一个正方形(不知道多大),如果新正方形的边长小于当前二分到的边长,那么就直接完事了。不然还是至少有一个小正方形,它的角和大正方形的角重合。

    然后再枚举第二个小正方形覆盖那个角,把已经覆盖的点去掉。

    现在要用一个正方形去覆盖一个正方形,可以直接判断。

    注意,要把之前操作的影响消除。

  • 相关阅读:
    ubuntu升级显卡驱动
    __slots__属性,声明实力属性名字列表
    isinstance 与 type 的区别
    conda使用技巧
    卷积神经网络参数
    apache nginx php不显示版本号
    30个实用的Linux find命令示例
    账号的管理的那点事
    Linux 命令整理 —— 基本操作
    Linux 命令整理 —— 用户管理
  • 原文地址:https://www.cnblogs.com/zengzk/p/15073295.html
Copyright © 2011-2022 走看看