当前位置: 首页 > 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.jsqmd.com/news/899317/

相关文章:

  • Seraphine:基于LCU API的英雄联盟智能助手完整指南
  • 第41次ccfcsp机器人项目管理
  • P1437 [HNOI2004] 敲砖块 题解
  • ChatGPT市场增长拐点已至?——基于217家B端客户采购决策链、LTV/CAC比值及替代率的预警分析(内部调研未公开版)
  • 哔哩下载姬DownKyi:如何轻松免费下载B站8K高清视频的完整指南
  • 3分钟掌握专业字体:设计师必备的思源宋体终极指南
  • 【司法部新规预警】:2024年起草合规性新规落地,ChatGPT法律文件必须通过这6道合规校验关卡
  • ChatGPT不是“黑盒工具”,而是新岗位:揭秘头部金融/医疗/制造企业正在紧急部署的9项KPI校准标准
  • 百度网盘限速无解?这个Python工具让你免费享受会员级下载速度
  • 动态相量模型与FPGA并行计算在混合MMC实时仿真中的应用
  • 2026西安财务外包怕踩坑?选长安德勤财税,告别乱账、错报、隐形消费! - 小柏云
  • 2026年 磁铁厂家/钕铁硼磁铁/异形磁铁/方形磁铁/圆形磁铁推荐榜:高矫顽力与精密磁组件的实力之选 - 品牌企业推荐师(官方)
  • SE-Net:从通道注意力到模型性能跃迁的深度解析
  • 百考通AI:实践报告智能生成,轻松输出专业内容
  • FPGA实现DCT-IV与FBMC多载波调制:SoC架构、定点量化与性能对比
  • 从llama.cpp演进看本地大模型部署:技术成熟度与实战指南
  • 3大核心功能解密:LizzieYzy如何成为围棋AI分析领域的瑞士军刀
  • 2026年同步带选型指南:双面齿、聚氨酯、橡胶与PU同步带品牌实力解析与工业应用推荐 - 品牌企业推荐师(官方)
  • 别再死记硬背了!用Python+ChatGPT帮你搞定《人工智能导论》课后习题
  • 抖音内容批量下载工具:5分钟掌握高效数据采集技巧
  • OBS多平台直播终极指南:obs-multi-rtmp插件一键同步推流到多个平台
  • 量子混合模型QLID-Net:在数据稀缺与噪声环境下提升非侵入式负荷识别性能
  • 2026低代码市占榜单:四大头部平台技术硬核横评
  • 混合优先级-松弛度调度算法:动态环境下实时非周期任务调度的工程实践
  • P3176 [HAOI2015] 数字串拆分 - Link
  • ChatGPT vs Claude 4 vs Gemini 2.5 Pro vs Qwen3 vs DeepSeek-R1:谁在中文长文本理解、代码生成与合规性上真正胜出?
  • 为什么你的ChatGPT写不出《雨巷》?——基于2372首训练诗集的语义张力分析,揭示诗歌生成中「陌生化」失效的3个隐藏断点
  • Visio导出矢量图总带白边?一个隐藏的‘打印属性’设置就能搞定(保姆级避坑教程)
  • 别再手动写手册了!:2024最新版ChatGPT员工手册生成工作流(含ISO 27001信息安全部分自动嵌入)
  • 构建内容审核辅助系统时集成多模型以提高判断准确性