トピックリンク:こちらをクリックして
思考:セット上の2つの辺のさえ合併を、それはリングがあったことを示す、同じコレクションにされている点のセットの両端で検出された場合。
ヒント:使用 二次元座標であり得ます ことを条件とする一次元座標に、 から 始めます。
#include<iostream>
#include<algorithm>
#include<cstdio>
#include<cstring>
using namespace std;
const int N = 40010;
int f[N];
int n, m;
int get(int x, int y)
{
return x * n + y;
}
int find(int x)
{
if(x != f[x]) f[x] = find(f[x]);
return f[x];
}
int main()
{
cin >> n >> m;
for(int i = 0; i < n * n; ++i) f[i] = i;
int res = 0;
for(int i = 1; i <= m; ++i)
{
int x, y;
char c;
cin >> x >> y >> c;
if(res) continue;
x--, y--; // 下标从0开始
int a, b;
a = get(x, y);
if(c == 'D') b = get(x + 1, y);
else b = get(x, y + 1);
int fa = find(a), fb = find(b);
if(fa == fb) res = i;
else f[fa] = fb;
}
if(res) cout << res << endl;
else cout << "draw" << endl;
return 0;
}