ZOJ 1093 最大高度

來源:互聯網
上載者:User
/*題意:給出n種箱子的3邊長,每種箱子有無窮個,你可以選擇任意兩條邊作為底面,疊在上面的箱子的地面的長寬必須嚴格小於下面的箱子,問能夠到達的最大高度 解析:枚舉每一种放置的形狀,排序預先處理,DP求最大高度 */#include<iostream>#include<cstdio>#include<algorithm>#include<string>#include<cmath>#include<cstring>using namespace std;#define manx 2000struct node{    int a,b,c;}x[manx];int dp[manx];bool comp(const node &x,const node &y){    return x.a<y.a || x.a==y.a && x.b<y.b;}int main(){    int n,ca=1;    while(cin>>n,n){        int num=0,a,b,c;        memset(dp,0,sizeof(dp));        for(int i=0;i<n;i++){            scanf("%d%d%d",&a,&b,&c);            x[num].a = a;            x[num].b = b;            x[num++].c = c;                        x[num].a = a;            x[num].b = c;            x[num++].c = b;                        x[num].a = b;            x[num].b = c;            x[num++].c = a;                        x[num].a = b;            x[num].b = a;            x[num++].c = c;                        x[num].a = c;            x[num].b = a;            x[num++].c = b;                        x[num].a = c;            x[num].b = b;            x[num++].c = a;        }        sort(x,x+num,comp);        dp[0] = x[0].c;        for(int i=1;i<num;i++){////            dp[i] = x[i].c;            for(int j=0;j<i;j++){////注意迴圈的意義                 if(x[i].a>x[j].a && x[i].b>x[j].b && dp[j]+x[i].c>dp[i]) /////                dp[i] = dp[j]+x[i].c;            }        }        int ans = 0;        for(int i=0;i<num;i++){            if(ans < dp[i]) ans = dp[i];        }        printf("Case %d: maximum height = %d\n",ca++,ans);    }}

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.