leetcode 2975

2975: 移除栅栏得到的正方形田地的最大面积

思路:暴力枚举正方形所有可能的边长

水平栅栏和垂直栅栏分开计算。

  • 对于水平栅栏,++任意两个栅栏之间的距离++(中间的栅栏全部删除)都可能是正方形的边长,存到一个哈希表 hSet 中。
  • 对于垂直栅栏,任意两个栅栏之间的距离(中间的栅栏全部删除)都可能是正方形的边长,存到一个哈希表 vSet 中。

答案是 hSet 和 vSet ++交集中的最大值++的平方,记得返回之前取模。如果交集为空,返回 −1。

复制代码
class Solution {
public:
    int maximizeSquareArea(int m, int n, vector<int>& hFences, vector<int>& vFences) {
        constexpr int MOD=1'000'000'007;
        auto f=[&](vector<int>& nums,int x)->unordered_set<int>{
            unordered_set<int> st; //正方形可能边长
            nums.push_back(1);
            nums.push_back(x);
            sort(nums.begin(),nums.end());
            for(int i=0;i<nums.size();i++){
                for(int j=i+1;j<nums.size();j++){
                    int d=nums[j]-nums[i];
                    if(d>0) st.insert(d);
                }
            }
            return st;
        };
        unordered_set<int> h=f(hFences,m);
        unordered_set<int> v=f(vFences,n);
        int best=-1;
        for(int x:h) if(v.count(x)) best=max(best,x);
        return best==-1 ? -1:(long long)best*best%MOD;
    }
};
相关推荐
少司府12 分钟前
C++进阶:红黑树
开发语言·数据结构·c++·b树·二叉树·红黑树
工业胶粘剂技术20 分钟前
单组分高温环氧结构胶 K-EP280 完整技术参数与工程选型分析
算法·制造
不会C语言的男孩31 分钟前
C++ Primer 第19章:特殊工具与技术
数据结构·c++
hnjzsyjyj1 小时前
东方博宜OJ 1010:数组元素的排序 ← 桶排序
数据结构·排序算法·桶排序
小欣加油1 小时前
Leetcode31 下一个排列
数据结构·c++·算法·leetcode·职场和发展
凤凰院凶涛QAQ1 小时前
《Java版数据结构 & 集合类剖析》链表与LinkedList:节点手拉手,增删不用愁
java·数据结构·链表
_日拱一卒1 小时前
LeetCode:39组合总和
java·算法·leetcode·职场和发展
无限进步_1 小时前
【Linux】进程状态、僵尸与孤儿、进程调度
linux·运维·服务器·开发语言·数据结构·算法
郝学胜-神的一滴1 小时前
力扣 662 :二叉树最大宽度
java·数据结构·c++·python·算法·leetcode·职场和发展
2301_764441332 小时前
基于Stackelberg博弈的分散式库存模型
python·算法·数学建模