[TK] 盖房子 hzoi-tg#262
同机房大佬也写了这题的 题解.
通解分析
此类问题我通常喜欢归纳成一类,即阻碍联通的坐标DP.
既然是阻碍联通,那么此类问题的通用思路是这样的:
首先将dp数组图形化. 一般用一个特定图形上的特定点来标识整个图形. 比如假如我需要找正方形的最大面积,我可以用左下角坐标来表示整个正方形. 找三角形最大面积,我可以用最上方顶点来表示整个三角形. 但这个标识一定要是确定的,假如我只用 顶点 来表示三角形,那么可表示的就太多了.
既然是坐标,那么我们一般使用一个二维dp数组. 数组里存放的是这个图形的相关信息,使得我们能完全确定这个图形,比如边长等.
随后,我们根据图形的特殊性,构造出一种用周围坐标推出当前坐标的状态转移方程.
我们来看一下具体的实例.
问题处理
对于这个题。依据上面的思路,我们定义一个二维数组 \(f[i][j]\) ,其中 \((i,j)\) 为正方形左下角的坐标, \(f[i][j]\) 中存储正方形的最大边长.
接下来我们这样初始化:令未损坏的坐标的最大边长都为 \(1\) ,其正确性不必证明.
然后进行状态转移方程的推理.
我们先来看从 \(1\) 如何变成 \(2\),这很容易想,因为我们定义的是正方形左下角的坐标,想要让这个坐标上的正方形边长为 \(2\) ,只需要在 \(1\) 的基础上,判断其右方,上方,右上方的三个格子是不是 \(1\) 即可.
接下来看如何从 \(2\) 变成 \(3\).
1 0 1 1
1 1 1 0
1 1 1 1
1 1 1 1
这是一块 \(4 \times 4\) 大小的地块. 对它进行一次 \(1\) 变成 \(2\) 的操作,使它变成这样:
1 0 1 1
1 1 1 0
2 2 1 1
2 2 2 1
注意到最左下角可以变为3,而它的右方,上方,右上方的三个格子都为2.
如此尝试几次,我们得出结论:一个格子右方,上方,右上方的三个格子都不小于 \(n\) 时,该格子为 \(n+1\).
所以有状态转移方程:
\]
因为每一次更新都要在上一数字的基础上,所以状态转移方程需要遍历 \(k\) 次(其中 \(k\) 是最大正方形边长,一般来说是 \(min(m,n)\) )
因此,该程序的时间复杂度为 \(O(nm·min(m,n))\),近似于 \(n^{3}\) .
但是这题 \(n=1000\) 的时候必炸,所以我们要想办法优化一下.
注意到,假如我们从右上角开始遍历,那么更新左下角正方形需要的所有正方形都会在它之前被更新,因此我们这样遍历只需要更新一次. 时间复杂度为 \(O(mn)\).
代码实现
点击查看代码
cin>>n>>m;
for(int i=1;i<=n;++i){
for(int j=1;j<=m;++j){
cin>>f[i][j];
}
}
for(int i=1;i<=n;++i){
for(int j=m;j>=1;--j){
if(f[i][j]){
f[i][j]=min({f[i-1][j],f[i][j+1],f[i-1][j+1]})+1;
ans=max(ans,f[i][j]);
}
}
}
cout<<ans;
[TK] 盖房子 hzoi-tg#262的更多相关文章
- tyvj1189 盖房子
描述 永恒の灵魂最近得到了面积为n*m的一大块土地(高兴ING^_^),他想在这块土地上建造一所房子,这个房子必须是正方形的.但是,这块土地并非十全十美,上面有很多不平坦的地方(也可以叫瑕疵).这些瑕 ...
- 【动态规划】盖房子(house)--未提交--已提交
问题 D: 盖房子(house) 时间限制: 1 Sec 内存限制: 64 MB提交: 27 解决: 16[提交][状态][讨论版] 题目描述 FJ最近得到了面积为n*m的一大块土地,他想在这块土 ...
- 盖房子(house)
盖房子(house) 题目描述 FJ最近得到了面积为n*m的一大块土地,他想在这块土地上建造一所房子,这个房子必须膏形的.但是,这块土地并非十全十美,上面有很多不平坦的地方(也可以叫瑕疵).这些瑕疵十 ...
- vijos 1057 盖房子 简单DP
描述 永恒の灵魂最近得到了面积为n*m的一大块土地(高兴ING^_^),他想在这块土地上建造一所房子,这个房子必须是正方形的. 但是,这块土地并非十全十美,上面有很多不平坦的地方(也可以叫瑕疵).这些 ...
- vijos 1057 盖房子 dp 最大子正方形
P1057盖房子 未递交 标签:[显示标签] 描述 永恒の灵魂最近得到了面积为n*m的一大块土地(高兴ING^_^),他想在这块土地上建造一所房子,这个房子必须是正方形的. 但是,这块土地并非十全十美 ...
- Vijos 1057 盖房子
二次联通门 : Vijos 1057 盖房子 /* Vijos 1057 盖房子 简单的dp 当前点(i, j)所能构成的最大的正方形的边长 为点(i - 1, j - 1)与(i, j - 1), ...
- 今儿直白的用盖房子为例,给你讲讲Java建造者模式
摘要:建造者模式(Builder Pattern)又叫生成器模式,是一种对象构建模式.它可以将复杂对象的建造过程抽象出来(抽象类别),使这个抽象过程的不同实现方法可以构造出不同表现(属性)的对象. 本 ...
- 模拟赛01 T3 盖房子
题面 http://zhengruioi.com/problem/248 题解 三重容斥(说是两重也行吧) 我们来看题目的约束 ①有k个位置不能放(k≤8) ②每行每列至少一个 ③正负对角线至少一个 ...
- Vijos1057 盖房子(DP经典题)
之前没有怎么刷过dp的题,所以在此学习了~(感谢walala大神的思路,给了我很大的启发) 也算是自己学习的另一种dp题型吧 先贴上状态转移方程: if(a[i][j]) f[i][j]=min(f[ ...
- ECNU 2018 10月月赛 E 盖房子 (bitset + 倍增)
题目链接 ECNU Monthly 2018.10 Problem E 从开场写到结束…… 显然要把三角形分成上下两部分. 把每一部分分成三部分,以上部分为例. 上面和右边,以及左下角的正方形. 也 ...
随机推荐
- [rCore学习笔记 03]配置rCore开发环境
写在前面 本随笔是非常菜的菜鸡写的.如有问题请及时提出. 可以联系:1160712160@qq.com GitHhub:https://github.com/WindDevil (目前啥也没有 rCo ...
- SpringBoot+ Sharding Sphere 轻松实现数据库字段加解密
一.介绍 在实际的软件系统开发过程中,由于业务的需求,在代码层面实现数据的脱敏还是远远不够的,往往还需要在数据库层面针对某些关键性的敏感信息,例如:身份证号.银行卡号.手机号.工资等信息进行加密存储, ...
- 关于使用UE5打包Android的测试
UE5打包Android,不同于UE4,在官方文档中需要Android studio 4.0或者3.5,还有Android SDK,NDK等 设置SetupAndroid, 在UE5 Editor配置 ...
- centos7 扩展硬盘
新增硬盘后 fdisk -l fdisk /dev/sdb (以后再加改成c) 阿里云叫vdb fdisk -l 注意,最好跟第一块硬盘一样! df -T 查看硬盘分区格式 注意,文件夹不能已存在的! ...
- 1分钟了解HashSet的使用
前言:刷leetcode的时候体验到hashset有多厉害了,用了他剪枝之后直接不爆超时了.速度大大滴快 使用方法 1.创建set对象Set<Integer>set=new HashSet ...
- 【Java】ElasticSearch 在项目里的应用
一.前言: 好久没写笔记了,最近忙一个项目,用到ES查询,以往的笔记写ES都是搭建环境,用Kibana玩一玩 这次是直接调用API操作了,话不多说,进入主题 二.环境前提: 公司用的还是纯Elasti ...
- 【Java】Properties 配置信息类
Properties 配置信息类 Properties 是HashTable的子类,该对象用于处理属性文件 由于属性文件的Key.Value都是字符串类型,所以Properties里的Key和Valu ...
- 【Vue】10 Vue-Cli 项目创建
简单的Demo案例并不需要Vue-Cli,因为一个页面之内可以总揽 但是真实的项目开发,考虑代码结构,目录结构,部署,热部署,单元测试... 代码量呈几何倍数增长,而且缺少轮子就写起来很痛苦 所以必须 ...
- 强化学习是否可以AI4Science呢?
最近,华为和Google都推出了AI的天气预报系统(发表了nature.science论文,但是没开放公众使用),可以说这个传统的Science问题已经被AI算法解决,这也说明了传统Science问题 ...
- linux中级——libcurl库访问百度
libcurl简介: libcurl是一个跨平台的网络协议库,支持http, https, ftp, gopher, telnet, dict, file, 和ldap 协议.libcurl同样支持H ...