【Leetcode】959. Regions Cut By Slashes

题目地址:

https://leetcode.com/problems/regions-cut-by-slashes/description/

给定一个 n × n n\times n n×n的网格,给出一个字符串数组 A A A A [ i ] [ j ] A[i][j] A[i][j]表示 ( i , j ) (i,j) (i,j)这个格子里的划线,划线有两种,一种是从左上到右下;另一种是从右上到左下;当然也可以没有划线。问这个网格被分成了多少个连通块。

参考https://blog.csdn.net/qq_46105170/article/details/119140758。代码如下:

class Solution {
 public:
  int n, res;
  vector<int> p;
  int find(int x) {
    if (p[x] != x) p[x] = find(p[x]);
    return p[x];
  }
  void merge(int x, int y) {
    int px = find(x), py = find(y);
    if (px != py) {
      p[px] = py;
      res--;
    }
  }
  int regionsBySlashes(vector<string>& g) {
    int n = g.size();
    res = 4 * n * n;
    p.resize(res);
    for (int i = 0; i < res; i++) p[i] = i;
    auto get = [&](int i, int j) { return (i * n + j) * 4; };
    for (int i = 0; i < n; i++)
      for (int j = 0; j < n; j++) {
        int a[4] = {get(i, j)};
        for (int k = 1; k < 4; k++) a[k] = a[0] + k;
        char ch = g[i][j];
        if (ch == ' ')
          for (int k = 1; k < 4; k++) merge(a[0], a[k]);
        else if (ch == '/')
          merge(a[0], a[1]), merge(a[2], a[3]);
        else if (ch == '\\')
          merge(a[1], a[2]), merge(a[0], a[3]);
        if (j < n - 1) merge(a[2], a[2] + 2);
        if (i < n - 1) merge(a[3], get(i + 1, j) + 1);
      }

    return res;
  }
};

时空复杂度 O ( n 2 log ⁡ ∗ n 2 ) O(n^2\log^*n^2) O(n2logn2),空间 O ( n 2 ) O(n^2) O(n2)

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值