2D Conveyer Belt:图论建模+洪水填充妙妙题。质量极高。

观察

首先面对这种不断往图里面加点或者边,且满足前面的答案可以由加边后推出的题,第一个想到的就得是倒序枚举加边过程的 trick。一个经典的例子就是并查集倒序枚举操作。

然后我们观察,什么形态的图才会导致陷入一个死循环中。显然,要一堆方格围起来形成一个封闭的区域。

那么我们判断一个点会不会陷入死循环的方式就出来了:

  • 若这个点还未确定方向,则与它四联通的点中只要有一个可以不陷入死循环,他就可以不陷入死循环。
  • 若这个点方向已确定,则只有它要去的点可以不陷入死循环,他才能不陷入死循环。

于是,当一个图形态确定时,我们可以通过泛洪算法来求出哪些点可以不陷入死循环中。实现上,我们从四个边界外出发,然后向内依次拓展,对于一个待拓展的点判断能否找到一个可以不让他陷入死循环的点,转移一下即可。

时间复杂度 \(O(n^2)\)。

去除限制

接下来就是要考虑如何倒序枚举加边过程,即不断将图中本来确定方向的点换成问号。

显然,确定方向是一个比问号更强的限制。一旦去掉这个限制,陷入死循环的点一定不会增加。

同时,如果一个点本来就不会陷入死循环,那么我们就没有必要进行这次改成问号的操作了。因为这样一定最优了。

那么如果这个点本来会陷入死循环呢?我们依然可以按上述判断方法判断这个点能否不陷入死循环。若可以不陷入,那么就把这个点 Flood Fill 一下,枚举与它四联通的点进行拓展即可。

由于每个点不会被拓展后又变回去,所以每个点最多被拓展一次。那么均摊下来,整题时间复杂度就是 \(O(n^2)\) 的了。

代码

实现上,我们可以在 dfs 内部判断是否已被填充,是的话就不拓展了。然后在一个点新拓展的时候遍历与它四联通的点,在待拓展点的递归内部判断能否填充。

#include <bits/stdc++.h>
#define fi first
#define se second
#define lc (p<<1)
#define rc ((p<<1)|1)
using namespace std;
typedef long long ll;
typedef unsigned long long ull;
typedef pair<int,int> pi;
int n,q,a[1005][1005],now=0;
int gox[]={0,0,1,-1};
int goy[]={1,-1,0,0};
int goc[]={2,1,4,3};
struct qry{
int x,y,tp,ans;
}b[200005];
bitset<1005>vis[1005];
bool legal(int x,int y)
{
return (x>=1&&x<=n&&y>=1&&y<=n);
}
void dfs(int x,int y)
{
if(vis[x][y])return;
bool flag=0;
if(a[x][y])
{
int tx=x+gox[goc[a[x][y]-1]-1],ty=y+goy[goc[a[x][y]-1]-1];
if(vis[tx][ty])flag=1;
}
else
{
for(int i=0;i<4;i++)
{
int tx=x+gox[i],ty=y+goy[i];
if(vis[tx][ty])flag=1;
}
}
if(!flag)return;
now++;
vis[x][y]=1;
for(int i=0;i<4;i++)
{
int tx=x+gox[i],ty=y+goy[i];
if(legal(tx,ty))dfs(tx,ty);
}
}
void init()
{
now=0;
for(int i=1;i<=n;i++)
{
vis[i][0]=1;
vis[0][i]=1;
vis[i][n+1]=1;
vis[n+1][i]=1;
}
for(int i=1;i<=n;i++)
{
dfs(i,1);
dfs(i,n);
dfs(1,i);
dfs(n,i);
}
}
int main()
{
//freopen("sample.in","r",stdin);
//freopen("sample.out","w",stdout);
ios::sync_with_stdio(0);
cin.tie(0);
cout.tie(0);
cin>>n>>q;
for(int i=1;i<=q;i++)
{
int x,y,tp;
char c;
cin>>x>>y>>c;
if(c=='L')tp=1;
else if(c=='R')tp=2;
else if(c=='U')tp=3;
else tp=4;
b[i]={x,y,tp,0};
a[x][y]=tp;
}
init();
for(int i=q;i>=2;i--)
{
b[i].ans=now;
a[b[i].x][b[i].y]=0;
dfs(b[i].x,b[i].y);
}
b[1].ans=now;
for(int i=1;i<=q;i++)cout<<n*n-b[i].ans<<'\n';
return 0;
}

USACO24DEC 2D Conveyer Belt S [ 蓝 ] [ 图论建模 ] [ Flood Fill ]的更多相关文章

  1. 【题解】284E. Coin Troubles(dp+图论建模)

    [题解]284E. Coin Troubles(dp+图论建模) 题意就是要你跑一个完全背包,但是要求背包的方案中有个数相对大小的限制 考虑一个\(c_i<c_j\)的限制,就是一个\(c_i\ ...

  2. 杭电ACM分类

    杭电ACM分类: 1001 整数求和 水题1002 C语言实验题——两个数比较 水题1003 1.2.3.4.5... 简单题1004 渊子赛马 排序+贪心的方法归并1005 Hero In Maze ...

  3. 转载:hdu 题目分类 (侵删)

    转载:from http://blog.csdn.net/qq_28236309/article/details/47818349 基础题:1000.1001.1004.1005.1008.1012. ...

  4. 玩转算法系列--图论精讲 面试升职必备(Java版)

    第1章 和bobo老师一起,玩转图论算法欢迎大家来到我的新课程:<玩转图论算法>.在这个课程中,我们将一起完整学习图论领域的经典算法,培养大家的图论建模能力.通过这个课程的学习,你将能够真 ...

  5. BZOJ2144 跳跳棋[建模+LCA]

    思维题,思路比较神仙. 个人思路过程:个人只想到了只要中间棋子开始向外跳了,以后就不应该向内跳了,这样很蠢.所以应该要么先向内跳一会,要么直接开始中间的向外跳.不知道怎么处理,就卡住了. 20pts: ...

  6. 【题解】Vijos1404 遭遇战(最短路图论套路)

    [题解]Vijos1404 遭遇战(最短路图论套路) 感觉一定要有建模的思想,不管什么东西要抽象建模之后再用算法解决... 求最短代价就可能可以用最短路,这句话不是强行解释,而是因为图论建模过后,可能 ...

  7. 单图像三维重建、2D到3D风格迁移和3D DeepDream

    作者:Longway Date:2020-04-25 来源:单图像三维重建.2D到3D风格迁移和3D DeepDream 项目网址:http://hiroharu-kato.com/projects_ ...

  8. poj1062

    经典的图论建模题: 先拿开的等级问题不看: 每个物品本身的价格就是有一个自定义源点到这个点距离: 有了A物品B物品优惠为W就代表由B到A的有向路权值为W: 最后的最小花费就是源点的点1的最短路径(酋长 ...

  9. NOIP 提高组必会!(转)

    1.排序算法(快排.选择.冒泡.堆排序.二叉排序树.桶排序)2.DFS/BFS 也就是搜索算法,剪枝务必要学! 学宽搜的时候学一下哈希表!3.树 ①遍历 ②二叉树 ③二叉排序树(查找.生成.删除) ④ ...

  10. HBSX2019 3月训练

    Day 1 3月有31天废话 今天先颓过了就只剩30天了 初步计划 每天一道字符串/数据结构题 图论学习 根据<若干图论模型探讨>(lyd)复习 二分图与网络流学习 <算法竞赛进阶指 ...

随机推荐

  1. .Net知识技能大全

    .Net知识技能大全 更多请见https://www.dotnetshare.com C#常见运算符 一元运算符(+.-.!.~.++.--) 算术运算符(*./.%.+. – ) 移位运算符(< ...

  2. 奇奇怪怪的编程语言:Malbolge

    Malbolge 除了我们日常使用的Python.Java.C等主流编程语言外,还存在这么一类极为晦涩难懂的编程语言,被称为深奥的编程语言(Esoteric programming language, ...

  3. three.js优化

    Three js 开发的一些知识整理,方便后期遇到类似的问题,能够及时查阅使用. three.js 性能优化方面,整理一下常用的优化方法或者方向,供大家一个优化思考的方向 尽量重用Material和G ...

  4. 鸿蒙UI开发快速入门 —— part07:组件状态管理之@Prop/@Link装饰器

    1.前言 我们在上一章学习了@State装饰器,@State装饰器的作用范围仅仅在当前组件,接下来,我们讨论如何从父组件中传入参数到子组件,让子组件随着父组件的状态发生变化.本章将要介绍的就是:@Pr ...

  5. WebP图片使用踩坑

    前情 WebP是一种同时提供了有损压缩与无损压缩(可逆压缩)的图片文件格式,最初在2010年发布,目标是减少文件大小,相较于传统的 PNG.JPG,甚至是动图 GIF 的格式,WebP 比它们的空间更 ...

  6. 数据分层 ODS DW DM层级

    在数据仓库的设计过程中,数据分层是一种重要的组织方式,能够提高数据处理效率和数据质量.数据分层通常包括原始数据(Operational Data Store,ODS).明细数据(Data Wareho ...

  7. 企业IT基础资源管理的“帮帮团”上线啦——源启云原生基础设施管理平台

    为助力企业提升基础资源一体化管理和交付效率,以更先进的基础设施管理方式来满足现代企业业务持续扩展和复杂化的需要,中电金信运用基础设施即代码(Infrastructure as Code,简称IaC)技 ...

  8. 《Kubernetes故障篇:calico/node is not ready: BIRD is not ready》

    文章目录一.背景信息二.解决方法总结:整理不易,如果对你有帮助,可否点赞关注一下? 一.背景信息k8s集群部署后发现calico的pod未通过健康检查,如下所示: 通过命令kubectl descri ...

  9. Qt音视频开发10-ffmpeg内核硬解码

    一.前言 为了极大的降低CPU的占用,实现硬解码(也叫硬件加速)非常有必要,一个视频文件或者一路视频流还好,如果增加到64路视频流呢,如果是4K.8K这种高分辨率的视频呢,必须安装上硬解码才是上上策. ...

  10. IM跨平台技术学习(四):蘑菇街基于Electron开发IM客户端的技术实践

    本文由蘑菇街前端技术团队分享,原题"Electron 从零到一",有修订和改动. 1.引言 本系列文章的前面几篇主要是从Electron技术本身进行了讨论(包括:第1篇初步了解El ...