zoukankan      html  css  js  c++  java
  • 302. Smallest Rectangle Enclosing Black Pixels My Submissions QuestionEditorial Solution

    An image is represented by a binary matrix with 0 as a white pixel and 1 as a black pixel. The black pixels are connected, i.e., there is only one black region. Pixels are connected horizontally and vertically. Given the location (x, y) of one of the black pixels, return the area of the smallest (axis-aligned) rectangle that encloses all black pixels.

    For example, given the following image:

    [
      "0010",
      "0110",
      "0100"
    ]
    

    and x = 0y = 2, return 6.

     1 public class Solution {
     2     public int minArea(char[][] image, int x, int y) {
     3         int m = image.length;
     4         int n = image[0].length;
     5         
     6         int left = bsHor(image, 0, y, 0, m, true);
     7         int right = bsHor(image, y+1, n, 0, m, false);
     8         int top = bsVer(image, 0, x, left, right, true);
     9         int bottom = bsVer(image, x+1, m, left, right, false);
    10         
    11         return (bottom - top) * (right - left);
    12     }
    13     
    14     private int bsHor(char[][] image, int i, int j, int top, int bottom, boolean leftSide) {
    15         while (i != j) {
    16             int k = top; 
    17             int mid = (j - i) / 2 + i;
    18             while (k<bottom && image[k][mid] == '0') k++;
    19             if (k < bottom == leftSide) {
    20                 j = mid;
    21             } else {
    22                 i = mid + 1;
    23             }
    24         }
    25         return i;
    26     }
    27     
    28     private int bsVer(char[][] image, int i, int j, int left, int right, boolean upSide) {
    29         while (i != j) {
    30             int k = left; 
    31             int mid = (j - i) / 2 + i;
    32             while (k<right && image[mid][k] == '0') k++;
    33             if (k < right == upSide) {
    34                 j = mid;
    35             } else {
    36                 i = mid + 1;
    37             }
    38         }
    39         return i;
    40     }
    41 }
  • 相关阅读:
    凡人修仙登录页面
    proxysql高可用~ keepalived+proxysql
    proxysql 系列 ~ 高可用架构
    mysql 案例 ~timeout相关问题与错误信息
    mysql 案例 ~ mysql字符集与大小写详解
    mysql案例~非常规操作汇总
    mysql原理~创建用户的那些事情
    mysql 案例 ~ 表空间迁移数据与数据导入
    开源统计数据库~行与列的讨论
    mysql 原理 ~ LRU 算法与buffer_pool
  • 原文地址:https://www.cnblogs.com/joycelee/p/5340668.html
Copyright © 2011-2022 走看看