当前位置: 首页 > news >正文

CF1749E - Cactus Wall

题目要让我们求一个形似最小割的东西,肯定是转成对偶图上跑最短路解决。

首先把不合法的格子去掉,然后你从左边界走到右边界,只能走斜对角的格子,代价即为路径经过的 . 个数。

跑一遍 01 BFS,记录一下前驱状态以便构造。

#include<cstdio>
#include<algorithm>
#define N 400005
#define M 1600005
using namespace std;const int inf=0x3f3f3f3f;
const int dx[]={-1,1,0,0},dy[]={0,0,-1,1},Dx[]={-1,-1,1,1},Dy[]={-1,1,-1,1};
int T,n,m,d[N],pre[N];
int tot,head[N],nxt[M],ver[M],e[M];
int lt,rt,q[N*4];
char s[N],ss[N];
bool vis[N],ban[N];
int id(int x,int y) {return (x-1)*m+y;}
bool check(int x,int y) {return x>=1&&x<=n&&y>=1&&y<=m;
}
void insert(int x,int y,int z) {ver[++tot]=y,e[tot]=z,nxt[tot]=head[x],head[x]=tot;
}
int main() {scanf("%d",&T);XJX:while(T--) {tot=0;for(int i=1;i<=n*m;i++) {head[i]=vis[i]=ban[i]=pre[i]=0;}scanf("%d%d",&n,&m);for(int i=1;i<=n;i++) {scanf("%s",ss+1);for(int j=1;j<=m;j++) {s[id(i,j)]=ss[j];if(s[id(i,j)]=='#') {for(int k=0;k<4;k++) {int x=i+dx[k],y=j+dy[k];if(check(x,y)) ban[id(x,y)]=1;}}}}for(int i=1;i<=n;i++) {for(int j=1;j<=m;j++) {if(ban[id(i,j)]) continue;for(int k=0;k<4;k++) {int x=i+Dx[k],y=j+Dy[k];if(check(x,y)&&!ban[id(x,y)]) insert(id(i,j),id(x,y),s[id(x,y)]=='.');}}}fill(d+1,d+n*m+1,inf);lt=N*2+1,rt=N*2;for(int i=1;i<=n;i++) {if(s[id(i,1)]=='.') d[id(i,1)]=1,q[++rt]=id(i,1);else d[id(i,1)]=0,q[--lt]=id(i,1);}while(lt<=rt) {int x=q[lt++]; vis[x]=1;for(int i=head[x];i;i=nxt[i]) {int y=ver[i],z=e[i];if(d[x]+z<d[y]) {d[y]=d[x]+z,pre[y]=x;if(z) q[++rt]=y; else q[--lt]=y;}}}int ans=inf,u=0;for(int i=1;i<=n;i++) {if(d[id(i,m)]<ans) ans=d[id(i,m)],u=id(i,m);}if(ans==inf) {puts("NO"); goto XJX;}while(u) s[u]='#',u=pre[u];puts("YES");for(int i=1;i<=n;i++) {for(int j=1;j<=m;j++) {putchar(s[id(i,j)]);}puts("");}}return 0;
}
http://www.rkmt.cn/news/187701.html

相关文章:

  • 2025大模型九大厂商全景复盘:从OpenAI到DeepSeek,2026十大趋势预判,小白程序员必学指南
  • 2025年耐水腻子粉厂家实力推荐:福州高彪建材,内墙/外墙/耐水腻子粉全品类供应 - 品牌推荐官
  • YOLOv8模型推理接口封装:构建RESTful API服务
  • Docker打造全能媒体中心Plex
  • rust生成器模式
  • 超详细PyTorch安装教程GPU版:支持YOLOv8高效运行
  • YOLOv8训练中断恢复技巧:断点续训配置方法
  • 微服务边界的“黄金分割律”:凭什么功能A和B不能放在一个服务里?
  • 震惊!国内188+26家大模型全解析,小白程序员秒变AI大神就靠这份清单!
  • 2025年路面步道板厂家实力推荐:哈尔滨钧楚建材,彩色/防滑/透水/水泥步道板全系供应 - 品牌推荐官
  • C# 集合表达式进阶指南(交错数组优化秘籍)
  • 【C# 12顶级语句增强深度解析】:掌握跨平台开发新利器,提升编码效率300%
  • 【.NET通信优化必修课】:基于拦截器的性能监控与故障预判方案
  • 快手知识付费课程:教小白学会使用AI开发环境
  • 2026现代简约风装修公司怎么选?这5家宝藏公司帮你划重点! - 品牌测评鉴赏家
  • 2025年毛坯房装修公司品牌怎么选?苏州这3家口碑好、适配本地需求的品牌别错过 - 品牌测评鉴赏家
  • 2025年工作服/科技行业工装/车间工厂服装推荐榜:江苏奋斗服饰等厂家,适配多元场景职业形象塑造 - 品牌推荐官
  • TPU支持情况说明:TensorFlow-v2.9能否发挥最大性能?
  • YOLOv8目标检测可视化输出:结果保存与标注格式转换
  • Java异常详解:从认知到实践的核心指南
  • YOLOv8项目初始化配置:git clone后必做的5件事
  • 哈尔滨律师事务所哪家可靠 - 行业平台推荐
  • 宝妈必收藏!儿童鞋服推荐全攻略:从学步期到青春期,选对品牌让成长更舒适 - 品牌测评鉴赏家
  • C++内核启动太慢?这4种静态配置优化方法你必须掌握
  • 8个降AI率工具推荐!研究生必备高效降AIGC方案
  • YOLOv8推理速度优化技巧:充分利用GPU算力资源
  • 2025年健康机器人品牌排行榜,新测评精选马博士机器人有实力吗 - 工业品牌热点
  • 2026重庆治疗儿童学习障碍医院推荐:效果好服务优的医院及科学治疗指南 - 品牌2026
  • 2025年如何选择现代灯具品牌以提升智能家居照明体验? - 睿易优选
  • 2025年企业增长战略的外部智慧整合与运用