• (中等) 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
  • 相关阅读:
    Microsoft .NET Framework v4.0 正确安装方法
    彻底解决C#实现DataTable导出EXCEL表格
    利用log4net记录操作日志
    [转]驱动程序开发—编译正传(5)
    [转]驱动程序开发-概述(1)
    论富客户端程序的webservice实现
    在Vista中编程控制防火墙设定(C#)
    [转]驱动程序开发—编译前传(4)
    C#系统较时
    [转]驱动程序开发—工具篇(2)
  • 原文地址:https://www.cnblogs.com/whywhy/p/4652199.html
Copyright © 2020-2023  润新知