zoukankan      html  css  js  c++  java
  • HDU

    题意:已知n种砖,每种砖有无穷多个,问这些砖最多能堆多高,要求堆放时,上面的砖摆放的长和宽必须都严格小于下面砖的长和宽。

    分析:

    1、将砖堆放时的堆放面上所有的长x和宽y统计出来,去重,且记录时保证x<y。每种砖最多能统计出三种长和宽。

    2、如果之前的砖比当前砖长和宽都严格小,则可将之前的砖放在这个砖上面dp[i] = max(dp[i], dp[j] + num[i].h);

    3、dp[i]---截止到第i块砖,能堆的最大高度。

    4、因为不知道哪个砖放在最底下,所以扫一遍,ans = max(ans, dp[i]);

    #include<cstdio>
    #include<cstring>
    #include<cstdlib>
    #include<cctype>
    #include<cmath>
    #include<iostream>
    #include<sstream>
    #include<iterator>
    #include<algorithm>
    #include<string>
    #include<vector>
    #include<set>
    #include<map>
    #include<stack>
    #include<deque>
    #include<queue>
    #include<list>
    #define lowbit(x) (x & (-x))
    const double eps = 1e-8;
    inline int dcmp(double a, double b){
        if(fabs(a - b) < eps) return 0;
        return a > b ? 1 : -1;
    }
    typedef long long LL;
    typedef unsigned long long ULL;
    const int INT_INF = 0x3f3f3f3f;
    const int INT_M_INF = 0x7f7f7f7f;
    const LL LL_INF = 0x3f3f3f3f3f3f3f3f;
    const LL LL_M_INF = 0x7f7f7f7f7f7f7f7f;
    const int dr[] = {0, 0, -1, 1, -1, -1, 1, 1};
    const int dc[] = {-1, 1, 0, 0, -1, 1, -1, 1};
    const int MOD = 1e9 + 7;
    const double pi = acos(-1.0);
    const int MAXN = 1000 + 10;
    const int MAXT = 10000 + 10;
    using namespace std;
    map<pair<int, int>, int> mp;
    struct Node{
        int x, y, h;
    }num[110];
    int dp[110];
    int main(){
        int N;
        int kase = 0;
        while(scanf("%d", &N) == 1){
            if(!N) return 0;
            memset(dp, 0, sizeof dp);
            mp.clear();
            int x, y, z;
            for(int i = 0; i < N; ++i){
                scanf("%d%d%d", &x, &y, &z);
                vector<int> v;
                v.push_back(x);
                v.push_back(y);
                v.push_back(z);
                sort(v.begin(), v.end());
                if(!mp.count(pair<int, int>(v[0], v[1]))){
                    mp[pair<int, int>(v[0], v[1])] = v[2];
                }
                if(!mp.count(pair<int, int>(v[1], v[2]))){
                    mp[pair<int, int>(v[1], v[2])] = v[0];
                }
                if(!mp.count(pair<int, int>(v[0], v[2]))){
                    mp[pair<int, int>(v[0], v[2])] = v[1];
                }
            }
            int cnt = 0;
            for(map<pair<int, int>, int>::iterator it = mp.begin(); it != mp.end(); ++it){
                num[cnt].x = (*it).first.first;
                num[cnt].y = (*it).first.second;
                num[cnt].h = (*it).second;
                ++cnt;
            }
            for(int i = 0; i < cnt; ++i){
                dp[i] = num[i].h;
                for(int j = 0; j < i; ++j){
                    if(num[j].x < num[i].x && num[j].y < num[i].y){
                        dp[i] = max(dp[i], dp[j] + num[i].h);
                    }
                }
            }
            int ans = 0;
            for(int i = 0; i < cnt; ++i){
                ans = max(ans, dp[i]);
            }
            printf("Case %d: maximum height = %d
    ", ++kase, ans);
        }
        return 0;
    }
    

      

  • 相关阅读:
    12-转盘
    11-UIView与核心动画对比
    10-动画组
    09-转场动画
    08-图片抖动(帧动画)
    07-心跳效果
    06-CABasicAnimation基础核心动画
    05-时钟效果
    计时器延迟 NSTimer和CADisplaylink GCD中的延迟
    ScrollView与UIPageController
  • 原文地址:https://www.cnblogs.com/tyty-Somnuspoppy/p/7346344.html
Copyright © 2011-2022 走看看