leetcode 3047

3047: 求交集区域内的最大正方形面积

bottomLeft[i]topRight[i] 分别代表第 i 个矩形的左下角右上角坐标。

如果两个矩形有交集,那么交集也是矩形。

求出这个交集矩形的左下角和右上角,就可以算出交集矩形的长和宽。

  • 左下角横坐标:两个矩形左下角横坐标的最大值。
  • 左下角纵坐标:两个矩形左下角纵坐标的最大值。
  • 右上角横坐标:两个矩形右上角横坐标的最小值。
  • 右上角纵坐标:两个矩形右上角纵坐标的最小值。

长和宽的最小值,就是能放入交集区域的正方形的最大边长 side。

最大的 side 的平方(正方形面积)即为答案。

优化:外层循环枚举的矩形,如果其长或宽 ≤maxSide,那么交集矩形的长或宽也 ≤maxSide,所以 maxSide 不会变大,无需跑内层循环,直接 continue。

复制代码
class Solution {
public:
    long long largestSquareArea(vector<vector<int>>& bottomLeft, vector<vector<int>>& topRight) {
        int max_side=0;
        for(int i=0;i<bottomLeft.size();i++){
            auto& b1=bottomLeft[i]; //取别名
            auto& t1=topRight[i];
            if(t1[0]-b1[0]<=max_side || t1[1]-b1[1]<=max_side) continue;
            for(int j=0;j<i;j++){
                auto& b2=bottomLeft[j];
                auto& t2=topRight[j];
                int width=min(t1[0],t2[0])-max(b1[0],b2[0]); //右上横坐标-左下横坐标
                int height=min(t1[1],t2[1])-max(b1[1],b2[1]); //右上纵坐标-左下纵坐标
                int side=min(width,height);
                max_side=max(max_side,side);
            }
        }

        return (long long)max_side*max_side;
    }
};
相关推荐
小雅痞1 小时前
[Java][Leetcode middle] 3. 无重复字符的最长子串
java·开发语言·leetcode
qeen871 小时前
【算法笔记】简单贪心
c++·笔记·算法·贪心算法
ting94520002 小时前
动手学深度学习(PyTorch版)深度详解(10): 优化算法 全解
人工智能·pytorch·深度学习·算法
ulias2122 小时前
leetcode热题 - 5
数据结构·算法·leetcode
Funny_AI_LAB2 小时前
Naval最新播客谈“氛围编码”:Vibe Coding 开启“一人独角兽”时代
人工智能·算法·语言模型·agi
如何原谅奋力过但无声2 小时前
【灵神高频面试题合集04-05】二分查找
数据结构·python·算法·leetcode
我不是懒洋洋2 小时前
【数据结构】排序算法(直接插入排序、希尔排序、选择排序、堆排序、冒泡排序、快速排序、归并排序、计数排序)
c语言·数据结构·c++·经验分享·算法·排序算法
MediaTea2 小时前
ML:逻辑回归的基本原理与实现
人工智能·算法·机器学习·数据挖掘·逻辑回归
辛苦才能2 小时前
数据结构--排序--插入排序(C语言,重点排序面试和比赛都会考察)
c语言·数据结构·面试
超级码力66611 小时前
【Latex文件架构】Latex文件架构模板
算法·数学建模·信息可视化