1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71
| #include<bits/stdc++.h> #define fo(i,a,b) for(int i=a;i<=b;i++) using namespace std;
typedef pair<int,int> pr;
const int maxn=5005;
int n,m; vector<int> e[maxn];
pr operator + (const pr &a,const pr &b) {return make_pair(a.first+b.first,a.second+b.second);}
void ReadChar(char &ch) { ch=getchar(); while (ch!='R' && ch!='B') ch=getchar(); }
int ga[maxn]; pr num[maxn]; int get(int x) {return ga[x]==x ?x :ga[x]=get(ga[x]) ;} void merge(int x,int y) { e[x].push_back(y), e[y].push_back(x); x=get(x), y=get(y); ga[x]=y; if (x!=y) num[y]=num[x]+num[y]; }
inline int calc(int x,int y) {return x*m+y*n-x*y;}
vector<pair<pr,int>> ans; bool vis[maxn]; void dfs(int k,int c) { vis[k]=1; for(int go:e[k]) if (!vis[go]) { if (c==0) ans.push_back(make_pair(make_pair(k,go-n),1)); else ans.push_back(make_pair(make_pair(go,k-n),0)); dfs(go,c^1); } }
int main() { scanf("%d %d",&n,&m); fo(i,1,n) ga[i]=i, num[i]=make_pair(1,0); fo(j,1,m) ga[n+j]=n+j, num[n+j]=make_pair(0,1); fo(i,1,n) fo(j,1,m) { char ch; ReadChar(ch); if (ch=='R') merge(i,n+j); } int compNum=0; pr compRB; fo(i,1,n+m) if (get(i)==i && num[i].first+num[i].second>1) { compNum++; compRB=compRB+num[i]; } if (calc(compRB.first-compNum,compRB.second)>calc(compRB.first,compRB.second-compNum)) { fo(i,1,n) if (!vis[i]) dfs(i,0); } else { fo(j,1,m) if (!vis[n+j]) dfs(n+j,1); } printf("%d\n",ans.size()); reverse(ans.begin(),ans.end()); for(auto p:ans) printf("%c %d %d\n",(p.second ?'Y' :'X' ),p.first.first,p.first.second); }
|