首先,对于一个在第 \(i\) 行 \(j\) 列的沙子,如果他开始下降,他能够使哪些沙子下降呢?

很容易得知是第 \(j-1,j,j+1\) 列所有行号不小于 \(i\) 的沙子。

对于沙子 \(u\) 下降能够使沙子 \(v\) 下降,我们连一条边 \((i,j)\)。然后缩点,对于度数为 \(0\) 的点,我们他不可能因为别的沙子下降而下降,所以我们得手动扰动这些沙子。

那么答案就是缩点后的图中度数为 \(0\) 的点的个数。

然而暴力连边的时空复杂度是 \(O(n^2m)\) 的,我们考虑省掉一些不要的边。

对于三个点 \((u,v,w)\),若存在边 \((u,v)\) 和 \((v,w)\),那么边 \((u,w)\) 明显可以被省掉。

根据这个优化,我们可以省掉很多边。

比如对于三个点 \(u,v,w\),其中 \(v\) 在 \(u\) 的左下方,\(w\) 在 \(v\) 正下方,那么 \(u\) 很明显只需要连接 \(v\) 而不需要连接 \(w\)。

所以,对于一个点,需要连接这些边:

  1. 若 \((i,j)\) 有一块沙子且 正上方一格 也有一块沙子,连接 \((i,j)\) 和 \((i-1,j)\);
  2. 若 \((i,j)\) 的正下方存在沙子,连接正下方第一块沙子;
  3. 若 \((i,j)\) 的下一列的下方存在沙子,连接下一列的下方第一块沙子;
  4. 若 \((i,j)\) 的上一列的下方存在沙子,连接上一列的下方第一块沙子;

对于 \(3\) 类边和 \(4\) 类边,反过来从左上/右上第一个沙子连接自己,预处理正上方第一块沙子即可。

当然也可以预处理正下方的第一块沙子,然后不反过来。

code:

#include<cstdio>
#include<vector>
const int M=4e5+5;
int n,m,ans,dfc,BCC,in[M],on[M],bl[M],dfn[M],low[M];std::vector<int>G[M];
bool val[M],istk[M];int top,stk[M];
inline int id(const int&x,const int&y){
return x?(x-1)*m+y:0;
}
inline int min(const int&a,const int&b){
return a>b?b:a;
}
inline char read_c(){
char s;while(s=getchar(),s!='.'&&s!='#');
return s;
}
void Tarjan(int u){
istk[stk[++top]=u]=true;
low[u]=dfn[u]=++dfc;
for(int&v:G[u]){
if(!dfn[v]){
Tarjan(v);
low[u]=min(low[u],low[v]);
}
else if(istk[v])low[u]=min(low[u],dfn[v]);
}
if(low[u]==dfn[u]){
register int v;++BCC;
do bl[v=stk[top--]]=BCC,istk[v]=false;while(v!=u);
}
}
signed main(){
register int i,j,lst;
scanf("%d%d",&n,&m);
for(i=1;i<=n;++i){
for(j=1;j<=m;++j){
on[id(i,j)]=(val[id(i,j)]=read_c()=='#')?id(i,j):on[id(i-1,j)];
}
}
for(j=1;j<=m;++j){
lst=0;
for(i=n;i>=1;--i){
if(!val[id(i,j)])continue;
if(lst)G[id(i,j)].push_back(lst);lst=id(i,j);
if(val[id(i-1,j)])G[id(i,j)].push_back(id(i-1,j));
if(j!=1&&on[id(i,j-1)])G[on[id(i,j-1)]].push_back(id(i,j));
if(j!=m&&on[id(i,j+1)])G[on[id(i,j+1)]].push_back(id(i,j));
}
}
for(i=1;i<=n*m;++i)if(!dfn[i]&&val[i])Tarjan(i);
for(i=1;i<=n*m;++i){
for(int&v:G[i])if(bl[v]!=bl[i])++in[bl[v]];
}
for(i=1;i<=BCC;++i)ans+=!in[i];
printf("%d\n",ans);
}

CF1534F1题解的更多相关文章

  1. 2016 华南师大ACM校赛 SCNUCPC 非官方题解

    我要举报本次校赛出题人的消极出题!!! 官方题解请戳:http://3.scnuacm2015.sinaapp.com/?p=89(其实就是一堆代码没有题解) A. 树链剖分数据结构板题 题目大意:我 ...

  2. noip2016十连测题解

    以下代码为了阅读方便,省去以下头文件: #include <iostream> #include <stdio.h> #include <math.h> #incl ...

  3. BZOJ-2561-最小生成树 题解(最小割)

    2561: 最小生成树(题解) Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 1628  Solved: 786 传送门:http://www.lyd ...

  4. Codeforces Round #353 (Div. 2) ABCDE 题解 python

    Problems     # Name     A Infinite Sequence standard input/output 1 s, 256 MB    x3509 B Restoring P ...

  5. 哈尔滨理工大学ACM全国邀请赛(网络同步赛)题解

    题目链接 提交连接:http://acm-software.hrbust.edu.cn/problemset.php?page=5 1470-1482 只做出来四道比较水的题目,还需要加强中等题的训练 ...

  6. 2016ACM青岛区域赛题解

    A.Relic Discovery_hdu5982 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/65536 K (Jav ...

  7. poj1399 hoj1037 Direct Visibility 题解 (宽搜)

    http://poj.org/problem?id=1399 http://acm.hit.edu.cn/hoj/problem/view?id=1037 题意: 在一个最多200*200的minec ...

  8. 网络流n题 题解

    学会了网络流,就经常闲的没事儿刷网络流--于是乎来一发题解. 1. COGS2093 花园的守护之神 题意:给定一个带权无向图,问至少删除多少条边才能使得s-t最短路的长度变长. 用Dijkstra或 ...

  9. CF100965C题解..

    求方程 \[ \begin{array}\\ \sum_{i=1}^n x_i & \equiv & a_1 \pmod{p} \\ \sum_{i=1}^n x_i^2 & ...

随机推荐

  1. JSP页面重定向与页面内容转发

    重定向:属于两次请求+响应,客户端浏览器地址栏会改变. 转发:属于一次请求+一次响应,客户端浏览器地址栏不会改变. 重定向: response.setHeader("action" ...

  2. sublime配置大全

    配置:Preferences→Settings-User 字体和字体大小 "font_face": "YaHei Consolas Hybrid", " ...

  3. springcloud+gateway微服务整合swagger

    单一的微服务集成swagger: maven: <dependency> <groupId>io.springfox</groupId> <artifactI ...

  4. 在Linux中设置php变量的方法

    默认情况下已经安装好了PHP环境,并且知道安装好后的PHP文件路径,然后可以通过以下的方式设置PHP变量,快速执行PHP命令运行PHP文件. 环境:centos 第一步:vi ~/.bash_prof ...

  5. 基于Xilinx XCKU115的半高PCIe x8 硬件加速卡

    一.板卡概述 本板卡系我公司自主研发,采用Xilinx公司的XCKU115-3-FLVF1924-E芯片作为主处理器,主要用于FPGA硬件加速.板卡设计满足工业级要求.如下图所示: 二.功能和技术指标 ...

  6. Solution -「NOI 2016」「洛谷 P1587」循环之美

    \(\mathcal{Description}\)   Link.   给定 \(n,m,k\),求 \(x\in [1,n]\cap\mathbb N,y\in [1,m]\cap \mathbb ...

  7. 多个UID为0的用户如何实现root用户的免密

    文章目录 创建用户 创建用户密码 免密脚本 当前主机用户不是root 当前主机用户是root,远程主机多个用户uid为0 利用shell脚本实现远程主机uid为0的用户只有root一个 多个UID=0 ...

  8. Java老码农心得:卷了这么多年,您真的卷会了吗?

    前言 大家好,我是福隆苑居士,今天跟大家聊一下程序员在当下内卷成风的情况下,使用什么方法可以了解行业发展趋势,知道哪些该学,哪些可以略过,今年应该掌握什么,可以放弃什么,让自己时刻紧跟行业的步伐永不掉 ...

  9. 自创Web框架之过度Django框架

    目录 自创Web框架之过度Django框架 软件开发架构 HTTP协议 Web框架之"撸起袖子加油干" Web框架之通过wsgiref加油干 封装优化处理 动静网页 jinjia2 ...

  10. Consul安装启动

    1.安装 sudo yum install -y yum-utils sudo yum-config-manager --add-repo https://rpm.releases.hashicorp ...