CF1534F2 Falling Sand (Hard Version) 题解

news/2025/1/15 14:41:44/文章来源:https://www.cnblogs.com/Farmer-djx/p/18403181

题目链接

点击打开链接

题目解法

  • 做法1
    一个沙子消失,会带走所有它所在列下面的沙子
    我们记每列从下往上第 \(a_i\) 个沙子为关键点,第 \(i\) 列至少消失 \(a_i\) 个沙子等价于所有关键点都消失
    一个显然的事情是:记一列最上面的沙子为起始点,则我们只会干扰起始点
    第一感觉是找到一个沙子可以干扰的所有起始点,但它并不是一个列上的区间
    但把这个东西反过来,一个沙子能被干扰到的起始点是一个区间
    证明:假设存在 \(i<k<R_i\)(左边部分类似),第 \(i\) 列的关键点不能被第 \(k\) 列的起始点干扰。如果第 \(R_i\) 列的起始点干扰第 \(i\) 列关键点的路径从第 \(k\) 列起始点的上方经过,那么第 \(k\) 列的起始点的起始点上方就有沙子,矛盾;如果路径从下方经过,那么第 \(k\) 列的起始点能干扰第 \(i\) 列的关键点,矛盾。
    不难用 \(dfs\) 求出所有关键点能被干扰到的起始点的区间,现在问题变成有很多区间,我们要选最少的点,使得每个区间中都存在选择的点
    这显然可以按右端点排序之后贪心求出
    时间复杂度 \(O(nm\log m)\)
  • 做法2
    沿用 F1 的思路,我们只把关键点缩点,且只需要关注度数为 \(0\) 的点
    根据做法 1 的结论,非关键点能干扰的度数为 \(0\) 的点是一个区间,然后类似做法 1 一样做就好了
    其实两个做法本质是相同的

做法 1 的代码:

#include <bits/stdc++.h>
#define F(i,x,y) for(int i=(x);i<=(y);i++)
#define DF(i,x,y) for(int i=(x);i>=(y);i--)
#define ms(x,y) memset(x,y,sizeof(x))
#define SZ(x) (int)x.size()-1
#define all(x) x.begin(),x.end()
#define pb push_back
using namespace std;
typedef long long LL;
typedef unsigned long long ull;
typedef pair<int,int> pii;
template<typename T> void chkmax(T &x,T y){ x=max(x,y);}
template<typename T> void chkmin(T &x,T y){ x=min(x,y);}
template<typename T> void read(T &FF){FF=0;int RR=1;char ch=getchar();for(;!isdigit(ch);ch=getchar()) if(ch=='-') RR=-1;for(;isdigit(ch);ch=getchar()) FF=(FF<<1)+(FF<<3)+ch-48;FF*=RR;
}
const int N=400010;
int n,m,a[N],L[N],R[N];
bool mp[N];
char str[N];
int ind(int x,int y){ return (x-1)*m+y;}
void dfs1(int x,int y,int col){if(L[ind(x,y)]) return;L[ind(x,y)]=col;if(x<n) dfs1(x+1,y,col);if(x>1&&mp[ind(x-1,y)]) dfs1(x-1,y,col);if(y>1&&mp[ind(x,y-1)]) dfs1(x,y-1,col);if(y<m&&mp[ind(x,y+1)]) dfs1(x,y+1,col);
}
void dfs2(int x,int y,int col){if(R[ind(x,y)]) return;R[ind(x,y)]=col;if(x<n) dfs2(x+1,y,col);if(x>1&&mp[ind(x-1,y)]) dfs2(x-1,y,col);if(y>1&&mp[ind(x,y-1)]) dfs2(x,y-1,col);if(y<m&&mp[ind(x,y+1)]) dfs2(x,y+1,col);
}
pii rng[N];
int main(){read(n),read(m);F(i,1,n){scanf("%s",str+1);F(j,1,m) if(str[j]=='#') mp[ind(i,j)]=1;}F(i,1,m) read(a[i]);F(j,1,m) F(i,1,n) if(mp[ind(i,j)]) dfs1(i,j,j);DF(j,m,1) F(i,1,n) if(mp[ind(i,j)]) dfs2(i,j,j);int cnt=0;F(j,1,m) if(a[j])DF(i,n,1) if(mp[ind(i,j)])if(!(--a[j])){rng[++cnt]={R[ind(i,j)],L[ind(i,j)]};break;}sort(rng+1,rng+cnt+1);int cur=0,ans=0;F(i,1,cnt) if(rng[i].second>cur) ans++,cur=rng[i].first;printf("%d\n",ans);return 0;
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/794106.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

LeetCode 刷题—树

不会做简单题目的小菜菜!一:树 1、树描述的是一个父子关系;有节点;根节点;叶子节点三个相关的概念 2、树的高度;深度;层 3、二叉树:每个节点最多只有两个孩子 4、完全二叉树:除了叶子节点;每个孩子并不要求都为两个孩子(从上到下,从左到右依次填满节点) 5、满二叉…

软件安装——STM32开发

安装Keil5 MDK 安装器件支持包 软件注册 安装STLINK驱动 安装USB转串口驱动安装Keil5 MDK 下载链接(来自B站江协科技) 通过百度网盘分享的文件:STM32入门教程资料 链接:https://pan.baidu.com/s/17_sbwMXU-xBVFA2sK0smrg?pwd=cgn6 提取码:cgn6 解压并安装Keil5MDK安装包中…

findbi测试连接失败

导入的jar包没问题,然后装一个隔离包如下名字。因为没重启

A Fast and High Quality Multilevel Scheme for Partitioning Irregular Graphs

目录概METISCoarseningPartitioning phaseUncoarsening phaseKarypis G. and Kumar V. A fast and high quality multilevel scheme for partitioning irregular graphs. SIAM, 1998.概 本文提出了一种 multilevel graph partitioning 方法. METISMETIS 的思想比较简单:首先对原…

小猪佩奇学英语——第五天——hide and seek

例句hide and seek,捉迷藏seek,寻找 find,找到了It is Georges turn to hide.Its our turn.用 is 是因为虽然我们是2个以上的人,但是我们是一组,轮到我们的只有一轮,所以是单数。 Its your turn.轮到你们了 Its theri turn.轮到他们了。Its sbs turn to .... 轮到某人做某…

小猪佩奇学英语——第六天——The Playgroup

第六天——The Playgroup 例句George,are you looking forward to the playgroup?乔治,你现在是不是正期待去托儿所。 look forward to sth 期待某物 look forward to doing...期待做某事 用looking表示正期待....maybe George is too small to go to my playgroup?too +形容…

实现人形角色的攀爬

在Unity实现角色攀爬 前言 开放世界类型的游戏近年也热门起来了,自由攀爬也成了这一类游戏的一大特色。攀爬给了玩家更多探索路径的选择,也让地图设计有了更多思路。这次,我们就来尝试在Unity中制作一个人形角色的攀爬。注:攀爬是一个角色完整动作系统的一部分,本文暂且抛…

LVDS(FPGA)

差分输入时钟缓冲器(IBUFDS)点击查看代码// IBUFDS: Differential Input Buffer// 7 Series// Xilinx HDL Language Template, version 2024.1IBUFDS #(.DIFF_TERM("FALSE"), // Differential Termination.IBUF_LOW_PWR("TRUE"), // L…

51nod 石子分配

可以发现步数限制把数轴变为了环。环之间不可以交换,环内相邻两点可以交换,然后我们只需要对每个环操作,最后累加。 对于环上的每个石子堆,我们需要将其石子数调整到均值 \(avg\)。因此,我们首先计算每个堆石子相对于 \(avg\) 的偏差,即 \(nowa[i] - avg\)。 因为相邻节点…

马哥教育C10网络安全课第四周作业2024_0831

网络安全C10-2024.8.31 作业: 1、安装burp并实现抓取HTTP站点的数据包(HTTPS站点暂时不要求) (1)安装Java 1.8.144; 设定操作系统环境变量 - JAVA_HOME jdk文件夹的绝对路径 例: JAVA_HOME=C:\Program Files\Java\jdk1.8.0_144 - CLASSPATH CLASSJPATH=.;%JAVA_HOME%\lib…

十年来(2015-2024)植物/农学领域有哪些学者戴上了杰青帽子?

2024年杰青建****议资助项目申请人名单(部分名单)(注:该表只是统计现公布的名单,欢迎留言补充) 2023年杰青建议资助项目申请人名单2022年杰青建议资助项目申请人名单2020年杰青建议资助项目申请人名单2019杰青建议资助项目申请人名单2018杰青建议资助项目申请人名单2017杰…