leetcode 3195.包含所有1的最小矩形面积I

1.题目要求:

2.解题步骤:

cpp 复制代码
class Solution {
public:
    int minimumArea(vector<vector<int>>& grid) {
        //设置二维数组
        deque<deque<int>> row_distance;
        for(int i = 0;i < grid.size();i++){
            //遍历数组,把每行头部1的小标和尾部1的下标代入其中
            deque<int> array;
            array.clear();
            int left = 0;
            int right = grid[i].size() - 1;
            while(left < grid[i].size()&&grid[i][left] != 1){
                left++;
            }
            if(left < grid[i].size()){
                array.push_back(left);
            }
            while(right >= 0&&grid[i][right] != 1){
                right--;
            }
            //如果没有下标,则此行的长度为0
            if(right >= 0){
                array.push_back(right);
            }
            row_distance.push_back(array);
        }
        //把二维数组的头部长度为0的去掉
        while(row_distance[0].size() == 0){
            row_distance.pop_front();
        }
        //把二维数组的尾部长度为0的去掉
        while(row_distance[row_distance.size() - 1].size() == 0){
            row_distance.pop_back();
        }
        //每行长度为零,代表此行无1
        //然后再遍历新数组,找到最长宽度,和最小宽度       
            int minwidth = 0;
            int maxwidth = 0;
            int flag = 1;
            for(int i = 0;i < row_distance.size();i++){
                for(int j = 0;j < row_distance[i].size();j++){
                    if(flag == 1){
                        minwidth = row_distance[i][j];
                        maxwidth = row_distance[i][j];
                        flag = 0;
                    }else{
                        if(row_distance[i][j] < minwidth){
                            minwidth = row_distance[i][j];
                        }
                        if(row_distance[i][j] > maxwidth){
                            maxwidth = row_distance[i][j];
                        }
                    }
                }
            }
            //最后返回值
            return row_distance.size() * (maxwidth - minwidth + 1);
    }
};
相关推荐
悠仁さん9 小时前
哈夫曼树的简单介绍
算法
bIo7lyA8v9 小时前
算法与数据结构协同优化的设计思想的技术8
数据结构·算法
2601_961194029 小时前
2026六级词汇资料电子版|大学英语六级核心词汇PDF
java·spring·eclipse·pdf·tomcat·hibernate
Lsk_Smion9 小时前
力扣实训 _ [98].验证二叉搜索树 _ 将二叉树展开成链表
数据结构·算法·leetcode
布朗克1689 小时前
18 面向对象综合实战——设计一个图书管理系统
java·面试·职场和发展·面向对象实战
8Qi89 小时前
LeetCode 377:组合总和 Ⅳ(Combination Sum IV)—— 题解 ✅
算法·leetcode·动态规划·完全背包
凯瑟琳.奥古斯特9 小时前
力扣1002题C++解法详解
开发语言·c++·算法·leetcode·职场和发展
码不停蹄的玄黓9 小时前
旁路缓存(Cache-Aside,CA)
java·开发语言
NGINX开源社区9 小时前
NGINX Ingress Controller 中的 Cache Policy:VirtualServer 实战指南
java·前端·nginx
CHHH_HHH10 小时前
【C++】红黑树:比AVL树更实用的平衡二叉搜索树
开发语言·数据结构·c++·算法·stl