日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

391. 完美矩形

發(fā)布時(shí)間:2023/11/29 编程问答 23 豆豆
生活随笔 收集整理的這篇文章主要介紹了 391. 完美矩形 小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

391. 完美矩形

給你一個(gè)數(shù)組 rectangles ,其中 rectangles[i] = [xi, yi, ai, bi] 表示一個(gè)坐標(biāo)軸平行的矩形。這個(gè)矩形的左下頂點(diǎn)是 (xi, yi) ,右上頂點(diǎn)是 (ai, bi) 。

如果所有矩形一起精確覆蓋了某個(gè)矩形區(qū)域,則返回 true ;否則,返回 false 。

示例 1:


輸入:rectangles = [[1,1,3,3],[3,1,4,2],[3,2,4,4],[1,3,2,4],[2,3,3,4]]
輸出:true
解釋:5 個(gè)矩形一起可以精確地覆蓋一個(gè)矩形區(qū)域。
示例 2:

輸入:rectangles = [[1,1,2,3],[1,3,2,4],[3,1,4,2],[3,2,4,4]]
輸出:false
解釋:兩個(gè)矩形之間有間隔,無法覆蓋成一個(gè)矩形。
示例 3:

輸入:rectangles = [[1,1,3,3],[3,1,4,2],[1,3,2,4],[3,2,4,4]]
輸出:false
解釋:圖形頂端留有空缺,無法覆蓋成一個(gè)矩形。
示例 4:

輸入:rectangles = [[1,1,3,3],[3,1,4,2],[1,3,2,4],[2,2,4,4]]
輸出:false
解釋:因?yàn)橹虚g有相交區(qū)域,雖然形成了矩形,但不是精確覆蓋。

提示:

  • 1 <= rectangles.length <= 2 * 10410^4104
  • rectangles[i].length == 4
  • ?105-10^5?105 <= xi, yi, ai, bi <= 10510^5105

解題思路

首先所有矩形需要組合成一個(gè)大的正常矩形,因此矩形之間不能存在空缺。并且因?yàn)榫匦沃g如果存在相交區(qū)域,雖然形成了矩形,但就不是精確覆蓋了。

  • 因此我們需要保證所有小矩形加起來的面積等于大矩形
  • 其次如果我們要保證沒有重疊的部分,就需要統(tǒng)計(jì)每個(gè)頂點(diǎn)出現(xiàn)的次數(shù),除了大矩形的四個(gè)頂點(diǎn)以外,每個(gè)頂點(diǎn)只能出現(xiàn)2次或者4次。如下圖所示,如果出現(xiàn)了重疊的部分,那么就會(huì)出現(xiàn)出現(xiàn)次數(shù)為1的頂點(diǎn)
  • 因此,在算法中,我們需要統(tǒng)計(jì)每個(gè)小矩形頂點(diǎn)的出現(xiàn)次數(shù)和其面積,只有當(dāng)其滿足上述兩個(gè)條件,才能實(shí)現(xiàn)精準(zhǔn)覆蓋

    代碼

    typedef pair<int, int> point;class Solution { public:bool isRectangleCover(vector<vector<int>> &rectangles) {map<point, int> m;long long area(0);int min_x1(rectangles[0][0]),min_y1(rectangles[0][1]),max_y2(rectangles[0][3]),max_x2(rectangles[0][2]);for (auto p:rectangles) {int x1 = p[0], y1 = p[1], x2 = p[2], y2 = p[3];min_x1=min(x1,min_x1);min_y1=min(y1,min_y1);max_x2=max(x2,max_x2);max_y2=max(y2,max_y2);m[{x1,y1}]+=1;m[{x1,y2}]+=1;m[{x2,y1}]+=1;m[{x2,y2}]+=1;area+=abs(x1-x2)*abs(y1-y2);}point p1{min_x1,min_y1},p2{min_x1,max_y2},p3{max_x2,min_y1},p4{max_x2,max_y2};if ((long long )abs(min_x1-max_x2)*(long long )abs(max_y2-min_y1)!=area||!m.count(p1)||!m.count(p2)||!m.count(p3)||!m.count(p4))return false;m.erase(p1);m.erase(p2);m.erase(p3);m.erase(p4);for(auto item:m){if (item.second!=2&&item.second!=4)return false;}return true;} }; 創(chuàng)作挑戰(zhàn)賽新人創(chuàng)作獎(jiǎng)勵(lì)來咯,堅(jiān)持創(chuàng)作打卡瓜分現(xiàn)金大獎(jiǎng)

    總結(jié)

    以上是生活随笔為你收集整理的391. 完美矩形的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

    如果覺得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。