前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >LeetCode 302. 包含全部黑色像素的最小矩形(BFS)

LeetCode 302. 包含全部黑色像素的最小矩形(BFS)

作者头像
Michael阿明
发布2021-02-19 10:09:34
7980
发布2021-02-19 10:09:34
举报
文章被收录于专栏:Michael阿明学习之路

文章目录

1. 题目

图片在计算机处理中往往是使用二维矩阵来表示的。

假设,这里我们用的是一张黑白的图片,那么 0 代表白色像素,1 代表黑色像素。

其中黑色的像素他们相互连接,也就是说,图片中只会有一片连在一块儿的黑色像素(像素点是水平或竖直方向连接的)。

那么,给出某一个黑色像素点 (x, y) 的位置,你是否可以找出包含全部黑色像素的最小矩形(与坐标轴对齐)的面积呢?

在这里插入图片描述
在这里插入图片描述
代码语言:javascript
复制
示例:
输入:
[
  "0010",
  "0110",
  "0100"
]
和 x = 0, y = 2

输出: 6

来源:力扣(LeetCode) 链接:https://leetcode-cn.com/problems/smallest-rectangle-enclosing-black-pixels 著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

2. 解题

  • 简单的模板题,BFS、DFS都可以做
  • 找两个方向坐标的极限值
代码语言:javascript
复制
class Solution {
    int x1 = INT_MAX, x2 = -1;
    int y1 = INT_MAX, y2 = -1;
public:
    int minArea(vector<vector<char>>& image, int x, int y) {
    	int m = image.size(), n = image[0].size(), i, j, nx, ny, k;
        vector<vector<int>> dir = {{1,0},{0,1},{0,-1},{-1,0}};
        queue<vector<int>> q;
        q.push({x,y});
        image[x][y] = '0';//访问过了
        while(!q.empty())
        {
        	i = q.front()[0];
        	j = q.front()[1];
        	q.pop();
        	x1 = min(x1, i);
        	x2 = max(x2, i);
        	y1 = min(y1, j);
        	y2 = max(y2, j);
        	for(k = 0; k < 4; ++k)
        	{
        		nx = i + dir[k][0];
        		ny = j + dir[k][1];
        		if(nx>=0 && nx<m && ny>=0 && ny<n && image[nx][ny]=='1')
        		{
        			q.push({nx, ny});
        			image[nx][ny] = '0';//访问过了
        		}
        	}
        }
        return (x2-x1+1)*(y2-y1+1);
    }
};

84 ms 14 MB

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2020/07/22 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 文章目录
  • 1. 题目
  • 2. 解题
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档