题目

给你一个数组 rectangles ,其中 rectangles[i] = [li, wi] 表示第 i 个矩形的长度为 li 、宽度为 wi

如果存在 k 同时满足 k <= lik <= wi ,就可以将第 i 个矩形切成边长为 k 的正方形。例如,矩形 [4,6] 可以切成边长最大为 4 的正方形。

maxLen 为可以从矩形数组 rectangles 切分得到的 最大正方形 的边长。

请你统计有多少个矩形能够切出边长为 maxLen 的正方形,并返回矩形 数目

来源:力扣(LeetCode)


解答

依次遍历每一个矩形即可。

当遍历到当前矩形时,得到当前矩形可以得到的最大正方形的边长,与保存的maxLen进行比较,如果大于maxLen,证明maxLen易值,且ret(即可获得maxLen正方形数量)重置为1;如果等于maxLen,则ret自增1。

最后返回ret即可。

具体见代码:

class Solution {
public:
    int countGoodRectangles(vector<vector<int>> &rectangles) {
        int n = rectangles.size();
        int maxLen = 0;
        int ret = 0;

        for (int i = 0; i < n; ++i) {
            int curLen = min(rectangles[i][0], rectangles[i][1]);
            if (curLen > maxLen) {
                maxLen = curLen;
                ret = 1;
            } else if (curLen == maxLen) {
                ret++;
            }
        }

        return ret;
    }
};