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

P3877 [TJOI2010] 打扫房间 - Link

题意

给一个 \(n\times m\) 的房间,有些位置是障碍。问能否在空地上画出若干条回路,使得每个空地恰好被经过一次。
\(n,m\le30\)

思路

直接插头 \(DP\)
不对,会 \(TLE\)
考虑用网络流。如果每个空地的度都是 \(2\),并且两条边不是连向同一个点,那么就是合法的。
用网络流刻画这个东西。

思路

// Problem: P3877 [TJOI2010] 打扫房间
// Contest: Luogu
// URL: https://www.luogu.com.cn/problem/P3877
// Memory Limit: 125 MB
// Time Limit: 1000 ms
// 
// Powered by CP Editor (https://cpeditor.org)#include<bits/stdc++.h>
using namespace std;
namespace IO{template<typename T>inline void read(T&x){x=0;char c=getchar();bool f=0;while(!isdigit(c)) c=='-'?f=1:0,c=getchar();while(isdigit(c)) x=x*10+c-'0',c=getchar();f?x=-x:0;}template<typename T>inline void write(T x){if(x==0){putchar('0');return ;}x<0?x=-x,putchar('-'):0;short st[50],top=0;while(x) st[++top]=x%10,x/=10;while(top) putchar(st[top--]+'0');}inline void read(char&c){c=getchar();while(isspace(c)) c=getchar();}inline void write(char c){putchar(c);}inline void read(string&s){s.clear();char c;read(c);while(!isspace(c)&&~c) s+=c,c=getchar();}inline void write(string s){for(int i=0,len=s.size();i<len;i++) putchar(s[i]);}template<typename T>inline void write(T*x){while(*x) putchar(*(x++));}template<typename T,typename...T2> inline void read(T&x,T2&...y){read(x),read(y...);}template<typename T,typename...T2> inline void write(const T x,const T2...y){write(x),putchar(' '),write(y...),sizeof...(y)==1?putchar('\n'):0;}
}using namespace IO;
const int maxn=50;
int n,m,fx[10]={0,0,0,1,-1},fy[10]={0,1,-1},bh[maxn][maxn];
char a[maxn][maxn];
namespace Network_Flow{const int inf=1000000000;template<int maxn,int maxm>class LSQXX{public:int head[maxn],nxt[maxm*2],to[maxm*2],val[maxm*2],cnt=1;void add(int u,int v,int w){nxt[++cnt]=head[u],to[cnt]=v,val[cnt]=w,head[u]=cnt;}void clear(){memset(head,0,sizeof(head));cnt=1;}};LSQXX<maxn*maxn,maxn*maxn*4>e;int s,t,d[maxn*maxn],cur[maxn*maxn];void edge_add(int u,int v,int w){e.add(u,v,w),e.add(v,u,0);}bool bfs(){for(int i=s;i<=t;i++) d[i]=inf;queue<int>q;q.push(s);d[s]=0;while(!q.empty()){int u=q.front();q.pop();for(int i=e.head[u];i;i=e.nxt[i]){int v=e.to[i];if(e.val[i]==0) continue;if(d[v]>d[u]+1) d[v]=d[u]+1,q.push(v);}}return d[t]!=inf;}int dfs(int u,int flow=inf){if(flow==0) return 0;if(u==t) return flow;int ans=0;for(int&i=cur[u];i;i=e.nxt[i]){int v=e.to[i];if(d[v]!=d[u]+1) continue;if(e.val[i]==0) continue;int new_flow=dfs(v,min(flow,e.val[i]));flow-=new_flow,ans+=new_flow;e.val[i]-=new_flow,e.val[i^1]+=new_flow;if(flow==0) return ans;}return ans;}void build(){e.clear();s=t=0;for(int i=1;i<=n;i++) for(int j=1;j<=m;j++) bh[i][j]=++t;t++;for(int i=1;i<=n;i++) for(int j=1;j<=m;j++){if(a[i][j]=='#') continue;if((i+j)&1) edge_add(bh[i][j],t,2);else{edge_add(s,bh[i][j],2);for(int f=1;f<=4;f++){int x=i+fx[f],y=j+fy[f];if(x<1||x>n||y<1||y>m) continue;if(a[x][y]=='#') continue;edge_add(bh[i][j],bh[x][y],1);}}}}int work(){int ans=0;while(bfs()){for(int i=s;i<=t;i++) cur[i]=e.head[i];ans+=dfs(s);}return ans;}
};
void solve(){read(n,m);for(int i=1;i<=n;i++) for(int j=1;j<=m;j++) read(a[i][j]);int cnt_bl=0,cnt_wh=0;for(int i=1;i<=n;i++) for(int j=1;j<=m;j++){if(a[i][j]=='#') continue;if((i+j)&1) cnt_bl++;else cnt_wh++;}if(cnt_bl!=cnt_wh){write("NO");return ;}Network_Flow::build();if(Network_Flow::work()==cnt_bl*2) write("YES");else write("NO");
}
signed main(){int T;read(T);while(T--) solve(),write("\n");return 0;
}
http://www.gsyq.cn/news/1407534.html

相关文章:

  • P1437 [HNOI2004] 敲砖块 题解
  • RL-ARM TCPNET PPP客户端IPCP协议支持解析与工程实践
  • 基于鸿蒙系统与Hi3861的WiFi小车:从零搭建跨平台遥控系统
  • 流量计生产商实战经验大公开:2026年排行预测及亲测案例分享
  • 3大核心功能解密:LizzieYzy如何成为围棋AI分析领域的瑞士军刀
  • 抖音内容批量下载工具:5分钟掌握高效数据采集技巧
  • SE-Net:从通道注意力到模型性能跃迁的深度解析
  • 哔哩下载姬DownKyi:如何轻松免费下载B站8K高清视频的完整指南
  • Visio导出矢量图总带白边?一个隐藏的‘打印属性’设置就能搞定(保姆级避坑教程)
  • ChatGPT vs Claude 4 vs Gemini 2.5 Pro vs Qwen3 vs DeepSeek-R1:谁在中文长文本理解、代码生成与合规性上真正胜出?
  • 速跃雅思103 登录后白屏问题排查:WebView2 Runtime 版本过旧导致
  • OBS多平台直播终极指南:obs-multi-rtmp插件一键同步推流到多个平台
  • 别再用SoapUI了!Postman搞定老旧WebService接口测试的保姆级教程
  • 百考通AI:实践报告智能生成,轻松输出专业内容
  • 第41次ccfcsp机器人项目管理
  • 2026年威海连锁海鲜餐馆推荐:5家正规门店深度测评,首选海滨小院 - 资讯纵览
  • 模型检验DAAC算法:高效检测所有反例,破解系统验证难题
  • 5款3D轻量化工具一键帮你解决卡顿问题
  • 《ZLToolKit源码学习笔记》(1)VS2019编译实战:从CMake配置到调试运行
  • Next.js集成Replicate AI:异步任务队列架构与生产级实践
  • 【Android】语燕输入法-无广纯净-输入快人一步-轻量纯净的高效输入之选
  • 基于时间序列深度学习的驾驶员认知分心检测:从多模态数据到嵌入式部署
  • 求职必备:手把手教你用学信网与学位网完成学历学位在线核验
  • Docker镜像构建与发布实战:从多阶段构建到生产部署
  • 20260527
  • ARF-LGN:基于非对称图卷积与注意力机制的社交推荐模型解析
  • 解锁AMD锐龙隐藏性能:SMUDebugTool深度调优秘籍
  • 5分钟搞定!Switch手柄在PC上玩转所有游戏的终极指南
  • 告别电量焦虑:给你的STM32项目加个‘油表’,HAL库ADC读取与电压换算详解
  • 告别格式焦虑!Zotero批量导出参考文献的终极指南