1250グリッドゲームをAcWing

トピックリンク:こちらをクリックして
ここに画像を挿入説明
ここに画像を挿入説明
思考:セット上の2つの辺のさえ合併を、それはリングがあったことを示す、同じコレクションにされている点のセットの両端で検出された場合。

ヒント:使用 バツ * n個 + X * N +と 二次元座標であり得ます バツ (X、Y) ことを条件とする一次元座標に、 バツ X、Y から 0 0 始めます。

#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;
}
844元記事公開 ウォンの賞賛135 ビュー150,000 +を

おすすめ

転載: blog.csdn.net/qq_42815188/article/details/105146768