AcWing 1250. 格子游戏(并查集)

题目链接

活动 - AcWing本课程系统讲解常用算法与数据结构的应用方式与技巧。icon-default.png?t=N7T8https://www.acwing.com/problem/content/1252/

题解

当两个点已经是在同一个连通块中,再连一条边,就围成一个封闭的圈。一般用x * n + y的形式将(x, y)变成一维。

代码

#include <cstdio>
#include <cstring>
#include <iostream>
#include <algorithm>

using namespace std;

const int N = 40010;

int n, m;
int p[N];

int get(int x, int y)
{
    return x * n + y;
}

int find(int x)
{
    if (p[x] != x) p[x] = find(p[x]);
    return p[x];
}

int main()
{
    cin >> n >> m;

    for (int i = 0; i < n * n; i++) p[i] = i;

    int res = 0;
    for (int i = 1; i <= m; i++)
    {
        int x, y;
        char d;
        cin >> x >> y >> d;
        x--, y--;
        int a = get(x, y);
        int b;
        if (d == 'D') b = get(x + 1, y);
        else b = get(x, y + 1);

        int pa = find(a), pb = find(b);
        if (pa == pb)
        {
            res = i;
            break;
        }
        p[pa] = pb;
    }

    if (!res) puts("draw");
    else cout << res << endl;

    return 0;
}

参考资料

  1. AcWing算法提高课

相关推荐

  1. 1250. 格子游戏

    2023-12-19 16:42:04       31 阅读
  2. AcWing 528. 奶酪 (

    2023-12-19 16:42:04       18 阅读
  3. Acwing2024蓝桥杯

    2023-12-19 16:42:04       14 阅读
  4. +01背包:1252. 搭配购买

    2023-12-19 16:42:04       30 阅读

最近更新

  1. TCP协议是安全的吗?

    2023-12-19 16:42:04       16 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2023-12-19 16:42:04       16 阅读
  3. 【Python教程】压缩PDF文件大小

    2023-12-19 16:42:04       15 阅读
  4. 通过文章id递归查询所有评论(xml)

    2023-12-19 16:42:04       18 阅读

热门阅读

  1. Linux 硬链接和软链接

    2023-12-19 16:42:04       44 阅读
  2. 【Spring】Spring AOP

    2023-12-19 16:42:04       30 阅读
  3. 计时器plus

    2023-12-19 16:42:04       43 阅读
  4. el-table表格中数据过长如何使用省略号

    2023-12-19 16:42:04       46 阅读
  5. CDN的特点及意义?

    2023-12-19 16:42:04       42 阅读
  6. kafka设置消费者组

    2023-12-19 16:42:04       44 阅读
  7. Ajax知识点大全

    2023-12-19 16:42:04       35 阅读