LeetCode 959. 由斜杠划分区域--放大图像+BFS搜索

本文介绍了一种通过放大图像并使用BFS搜索算法来计算由斜杠划分的区域数量的方法。具体地,将每个1x1方格中的'/',''符号放大为3x3的模式,并在一个更大的图像上进行搜索,以确定由0构成的不同区域的数量。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

  1. 由斜杠划分区域

在由 1 x 1 方格组成的 N x N 网格 grid 中,每个 1 x 1 方块由 /、\ 或空格构成。这些字符会将方块划分为一些共边的区域。

(请注意,反斜杠字符是转义的,因此 \ 用 “\” 表示。)。

返回区域的数目。

示例 1:

输入:
[
" /",
"/ "
]
输出:2
解释:2x2 网格如下:
在这里插入图片描述

示例 2:

输入:
[
" /",
" "
]
输出:1
解释:2x2 网格如下:
在这里插入图片描述

示例 3:

输入:
[
“\/”,
“/\”
]
输出:4
解释:(回想一下,因为 \ 字符是转义的,所以 “\/” 表示 /,而 “/\” 表示 /\。)
2x2 网格如下:
在这里插入图片描述

示例 4:

输入:
[
“/\”,
“\/”
]
输出:5
解释:(回想一下,因为 \ 字符是转义的,所以 “/\” 表示 /\,而 “\/” 表示 /。)
2x2 网格如下:
在这里插入图片描述

示例 5:

输入:
[
“//”,
"/ "
]
输出:3
解释:2x2 网格如下:

在这里插入图片描述

提示:

1 <= grid.length == grid[0].length <= 30
grid[i][j] 是 '/'、'\'、或 ' '。

题解

比较简单的思路,就是直接把图像放大,比如‘/’放大就是
001
010
100
同理‘\’放大就是
100
010
001
那么就会构成一个比较大的图像,我们对这个图像进行BFS搜索,就可以很方便的知道有多少个以0构成的不同区域。

AC代码

class Solution {
public:
    struct Node
    {
        int x,y;
    };
    queue<Node>q;
    bool mp[310][310];
    int xx[4]={0,0,1,-1};
    int yy[4]={1,-1,0,0};
    bool vis[310][310];
    int n;
    void bfs(int X,int Y)
    {
        while(!q.empty())q.pop();
        Node t;
        t.x=X,t.y=Y;
        q.push(t);
        while(!q.empty())
        {
            t=q.front();
            q.pop();
            for(int i=0;i<4;i++)
            {
                Node w;
                w.x=t.x+xx[i];
                w.y=t.y+yy[i];
                if(w.x<0||w.x>=3*n||w.y<0||w.y>=3*n)continue;
                if(vis[w.x][w.y]==false&&mp[w.x][w.y]==0)
                {
                    vis[w.x][w.y]=true;
                    q.push(w);
                }
            }
        }
    }
    int regionsBySlashes(vector<string>& grid) 
    {
        memset(mp,0,sizeof(mp));
        memset(vis,0,sizeof(vis));
        n=grid.size();
        cout<<n<<endl;
        for(int i=0;i<n;i++)
        {
            for(int j=0;j<n;j++)
            {
                if(grid[i][j]=='\\')
                {
                    mp[3*i][3*j]=1;
                    mp[3*i+1][3*j+1]=1;
                    mp[3*i+2][3*j+2]=1;
                }
                else if(grid[i][j]=='/')
                {
                    mp[3*i][3*j+2]=1;
                    mp[3*i+1][3*j+1]=1;
                    mp[3*i+2][3*j]=1;
                }
            }
        }
        int ans=0;
        for(int i=0;i<3*n;i++)
        {
            for(int j=0;j<3*n;j++)
            {
                if(mp[i][j]==0&&vis[i][j]==false)
                {
                    ans++;
                    bfs(i,j);
                }
            }
        }
        return ans;
    }
};

在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值