zoukankan      html  css  js  c++  java
  • (中等) POJ 2482 Stars in Your Window,静态二叉树。

    Description
      Here comes the problem: Assume the sky is a flat plane. All the stars lie on it with a location (x, y). for each star, there is a grade ranging from 1 to 100, representing its brightness, where 100 is the brightest and 1 is the weakest. The window is a rectangle whose edges are parallel to the x-axis or y-axis. Your task is to tell where I should put the window in order to maximize the sum of the brightness of the stars within the window. Note, the stars which are right on the edge of the window does not count. The window can be translated but rotation is not allowed.
     
      题意就是给平面上的一些星星,然后用一个矩形去覆盖,能覆盖到的最大值。
     
      被这个题卡了一天,好坑,要注意数据范围,y坐标加上H就会超int了,然后就是用静态二叉树做的话注意建的树不一定是完全二叉树,所以要注意越界问题和内存空间问题,还有要把数组都清零。
     
      算法的话就是先以每个y和y+H建一个二叉树,然后从左到右,以每个点为最左边,然后把在带状范围内的加进提前建好的静态二叉树,其中y点加上c,y+H点减去c,然后二叉树维护子节点的和自己的值的和,以及最大的前缀和。
     
    代码如下:
    // ━━━━━━神兽出没━━━━━━
    //    ┏┓       ┏┓
    //   ┏┛┻━━━━━━━┛┻┓
    //   ┃           ┃
    //   ┃     ━     ┃
    //     ████━████   ┃
    //   ┃           ┃
    //   ┃    ┻      ┃
    //   ┃           ┃
    //   ┗━┓       ┏━┛
    //     ┃       ┃
    //     ┃       ┃
    //    ┃       ┗━━━┓
    //    ┃           ┣┓
    //    ┃           ┏┛
    //    ┗┓┓┏━━━━━┳┓┏┛
    //     ┃┫┫     ┃┫┫
    //     ┗┻┛     ┗┻┛
    //
    // ━━━━━━感觉萌萌哒━━━━━━
    
    // Author        : WhyWhy
    // Created Time  : 2015年07月16日 星期四 16时33分23秒
    // File Name     : 2482_1.cpp
    
    // 注意:建的不是完全二叉树,所以空间要开大,然后就是注意lc和rc的越界问题(不知如何判,所以直接初始化为0)。
    
    #include <stdio.h>
    #include <string.h>
    #include <iostream>
    #include <algorithm>
    #include <vector>
    #include <queue>
    #include <set>
    #include <map>
    #include <string>
    #include <math.h>
    #include <stdlib.h>
    #include <time.h>
    
    using namespace std;
    
    const int MaxN=80004;
    
    #define lc (po<<1)
    #define rc ((po<<1)|1)
    
    struct DE
    {
        int a,b,c;
    
        bool operator < (const DE &b) const
        {
            return c<b.c;
        }
    }de[MaxN];
    
    int decou=0;
    
    struct BIT
    {
        int N;
        long long key[MaxN],val[MaxN];
        long long *numP;
    
        long long SUM[MaxN],MAXN[MaxN];
    
        void _build(int L,int R,int po)
        {
            if(L>R)
                return;
    
            de[decou].a=L;
            de[decou].b=R;
            de[decou].c=po;
            ++decou;
            
            int M=(L+R+1)>>1;
    
            _build(L,M-1,lc);
    
            key[po]=numP[M];
            val[po]=0;
            SUM[po]=MAXN[po]=0;
            
            _build(M+1,R,rc);
        }
    
        void build(long long *num,int cou)
        {
            N=cou;
            numP=num;
            memset(SUM,0,sizeof(SUM));
            memset(MAXN,0,sizeof(MAXN));
            _build(1,N,1);
        }
    
        void pushUP(int po)
        {
    /*        long long Lnum,Rnum,Rmaxn,Lmaxn;
    
            if(lc>N)
                Lnum=Lmaxn=0;
            else
            {
                Lnum=SUM[lc];
                Lmaxn=MAXN[lc];
            }
    
            if(rc>N)
                Rnum=Rmaxn=0;
            else
            {
                Rnum=SUM[rc];
                Rmaxn=MAXN[rc];
            }
    
            SUM[po]=Lnum+Rnum+val[po];
            MAXN[po]=max(Lmaxn,max(Lnum+val[po]+Rmaxn,Lnum+val[po]));*/
    
            SUM[po]=SUM[lc]+SUM[rc]+val[po];
            MAXN[po]=max(MAXN[lc],SUM[lc]+val[po]+max(0LL,MAXN[rc]));
        }
    
        void _add(int po,long long k,long long num)
        {
        //    if(po>N)
        //        return;
    
            if(k==key[po])
                val[po]+=num;
            else if(k<key[po])
                _add(lc,k,num);
            else
                _add(rc,k,num);
    
            pushUP(po);
        }
    
        void add(long long k,long long num)
        {
            _add(1,k,num);
        }
    
        long long query()
        {
            return MAXN[1];
        }
    
        void display()
        {
            for(int i=1;i<=N;++i)
                cout<<key[i]<<' '<<val[i]<<' '<<SUM[i]<<' '<<MAXN[i]<<endl;
            cout<<endl;
        }
    };
    
    BIT tree;
    
    struct Point
    {
        long long x,y,val;
    
        bool operator < (const Point &b) const
        {
            if(x==b.x)
                return y<b.y;
    
            return x<b.x;
        }
    };
    
    Point P[MaxN];
    int N;
    long long W,H;
    int cou;
    long long num[MaxN];
    long long ans;
    
    long long getans()
    {
        if(W==0 || H==0)
            return 0;
    
        int Lp,Rp;
    
        Lp=Rp=1;
    
        for(int i=1;i<=N;++i)
        {
            while(Lp<=N && P[Lp].x<P[i].x)
            {
                tree.add(P[Lp].y,-P[Lp].val);
                tree.add(P[Lp].y+H,P[Lp].val);
                ++Lp;
            }
    
            while(Rp<=N && P[Rp].x<P[i].x+W)
            {
                tree.add(P[Rp].y,P[Rp].val);
                tree.add(P[Rp].y+H,-P[Rp].val);
                ++Rp;
            }
    
            ans=max(ans,tree.query());
        }
    
        return ans;
    }
    
    int main()
    {
        //freopen("in.txt","r",stdin);
        //freopen("out.txt","w",stdout);
    
        while(~scanf("%d %lld %lld",&N,&W,&H))
        {
            ans=0;
            cou=0;
    
            for(int i=1;i<=N;++i)
            {
                scanf("%lld %lld %lld",&P[i].x,&P[i].y,&P[i].val);
                num[++cou]=P[i].y;
                num[++cou]=P[i].y+H;
            }
    
            sort(P+1,P+N+1);
            sort(num+1,num+cou+1);
            cou=unique(num+1,num+cou+1)-num-1;
    
            tree.build(num,cou);
    
            printf("%lld
    ",getans());
        }
        
        return 0;
    }
    View Code
  • 相关阅读:
    UVa 10010 Where's Waldorf?
    boost 学习笔记
    C++ enum类型的一个更好的用法
    新浪面试题:删除字符串中多余的空格
    微软面试题:写程序找出二叉树的深度
    c++中sizeof的分析
    复习计划
    boost学习之 时间和日期 timer
    c++ template学习总结3
    微软面试题:反序一个单向链表
  • 原文地址:https://www.cnblogs.com/whywhy/p/4652199.html
Copyright © 2011-2022 走看看