日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁(yè) >

SDUT 2401 最大矩形面积

發(fā)布時(shí)間:2025/5/22 34 豆豆
生活随笔 收集整理的這篇文章主要介紹了 SDUT 2401 最大矩形面积 小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

http://acm.sdut.edu.cn/sdutoj/problem.php?action=showproblem&problemid=2401

話說GSB 出的這個(gè)題確實(shí)不大好想,給定題意不說了。

才開始我們想的是從左到右,從上往下走一邊,找相鄰連點(diǎn)兩重循環(huán)找最大面積,敲出來一交WA,郁悶,才開始我們都認(rèn)為這個(gè)辦法對(duì),想了很長(zhǎng)時(shí)間,到最后ZC出了各情況直接給否定了,主要是我們沒有考慮上下界問題。同樣只要考慮好上下界,還是按那個(gè)思路左右上下走一邊,最后求出最大值即可。

View Code #include <cstdio> #include <cstring> #include <iostream> #include <algorithm> #define maxn 1007 using namespace std;struct node {int x,y; }p[maxn]; int n,tal,l,w; int cmpx(node a,node b) {if (a.x != b.x) return a.x < b.x;else return a.y < b.y; } int cmpy(node a,node b) {if (a.y != b.y) return a.y < b.y;else return a.x < b.x; } int LR() {int i,j,ans;ans = 0;for (i = 0; i < tal; ++i){int top = w, down = 0;for (j = i + 1; j < tal; ++j){if (p[i].x != p[j].x){ans = max(ans,(p[j].x - p[i].x)*(top - down));//更新上下界if (p[j].y > p[i].y) top = min(top,p[j].y);else down = max(down,p[j].y);}}}return ans; } int UD() {int i,j,ans;ans = 0;for (i = 0; i < tal; ++i){int L = 0, R = l;for (j = i + 1; j < tal; ++j){if (p[i].y != p[j].y){ans = max(ans,(p[j].y - p[i].y)*(R - L));//更新左右界if (p[j].x > p[i].x) R = min(R,p[j].x);else L = max(L,p[j].x);}}}return ans; } int main() {//freopen("data.in","r",stdin);int i,t;scanf("%d",&t);while (t--){scanf("%d%d",&l,&w);scanf("%d",&n);if (n == 0){printf("%d\n",l*w);continue;}//作為結(jié)束的邊界p[0].x = p[0].y = 0;p[1].x = l; p[1].y = w;tal = 2;for (i = 0; i < n; ++i){scanf("%d%d",&p[tal].x,&p[tal].y);tal++;}//按X軸排序,從左到右查找sort(p,p+tal,cmpx);int l = LR();//按Y軸排序從上往下查找sort(p,p+tal,cmpy);int d = UD();//取最大值printf("%d\n",max(l,d));}return 0; }

轉(zhuǎn)載于:https://www.cnblogs.com/E-star/archive/2012/04/23/2467028.html

總結(jié)

以上是生活随笔為你收集整理的SDUT 2401 最大矩形面积的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問題。

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