• SPOJ GSS1 Can you answer these queries I[线段树]


    Description

    You are given a sequence A[1], A[2], ..., A[N] . ( |A[i]| ≤ 15007 , 1 ≤ N ≤ 50000 ). A query is defined as follows: 
    Query(x,y) = Max { a[i]+a[i+1]+...+a[j] ; x ≤ i ≤ j ≤ y }. 
    Given M queries, your program must output the results of these queries.

    Input

    • The first line of the input file contains the integer N.
    • In the second line, N numbers follow.
    • The third line contains the integer M.
    • M lines follow, where line i contains 2 numbers xi and yi.

    Output

      Your program should output the results of the M queries, one query per line.

    Example

    Input:
    3 
    -1 2 3
    1
    1 2
    Output:
    2

    动态最大子段和
    维护区间和sum,最大连续和mx,最大前缀和pre,最大后缀和suf
    用了三个查询,子段,前缀和后缀
    考虑最大的起点和终点位置然后更新
    #include <iostream>
    #include <cstdio>
    #include <algorithm>
    #include <cstring>
    #define m ((l+r)>>1)
    #define lson o<<1,l,m
    #define rson o<<1|1,m+1,r
    #define lc o<<1
    #define rc o<<1|1
    using namespace std;
    typedef long long ll;
    const int N=5e5+5,INF=2e9+5;
    inline int read(){
        char c=getchar();int x=0,f=1;
        while(c<'0'||c>'9'){if(c=='-')f=-1;c=getchar();}
        while(c>='0'&&c<='9'){x=x*10+c-'0';c=getchar();}
        return x*f;
    }
    int n,q,x,y;
    struct node{
        int sum,mx,pre,suf;
    }t[N<<2];
    void merge(int o){
        t[o].sum=t[lc].sum+t[rc].sum;
        t[o].mx=max(t[lc].suf+t[rc].pre,max(t[lc].mx,t[rc].mx));
        t[o].pre=max(t[lc].pre,t[lc].sum+t[rc].pre);
        t[o].suf=max(t[rc].suf,t[rc].sum+t[lc].suf);
    }
    void build(int o,int l,int r){
        if(l==r) t[o].sum=t[o].mx=t[o].pre=t[o].suf=read();
        else{
            build(lson);
            build(rson);
            merge(o);
        }
    }
    int qpre(int o,int l,int r,int ql,int qr){
        if(ql<=l&&r<=qr) return t[o].pre;
        else if(qr<=m) return qpre(lson,ql,qr);
        else return max(qpre(lson,ql,qr),t[lc].sum+qpre(rson,ql,qr));
    }
    int qsuf(int o,int l,int r,int ql,int qr){
        if(ql<=l&&r<=qr) return t[o].suf;
        else if(m<ql) return qsuf(rson,ql,qr);
        else return max(t[rc].suf,t[rc].sum+qsuf(lson,ql,qr));
    }
    int qmx(int o,int l,int r,int ql,int qr){
        if(ql<=l&&r<=qr) return t[o].mx;
        else{
            int ans=-INF;
            if(ql<=m) ans=max(ans,qmx(lson,ql,qr));
            if(m<qr) ans=max(ans,qmx(rson,ql,qr));
            if(ql<=m&&m<qr) ans=max(ans,qsuf(lson,ql,qr)+qpre(rson,ql,qr));
            return ans;
        }
    }
    
    int main(){
        n=read();
        build(1,1,n);
        q=read();
        for(int i=1;i<=q;i++){
            x=read();y=read();
            printf("%d
    ",qmx(1,1,n,x,y));
        }
    }
     
  • 相关阅读:
    Web前端浏览器兼容性问题及解决方案
    JS
    vue element-ui 重置样式问题
    学习的一些文章链接
    打开新世界的第一步:学习servlet
    java学习初体验之课后习题
    下载、安装jdk8(Windows下)并配置变量环境
    下载PhpStorm并进行激活
    WCF+NHibernate 序列化
    wcf 证书+ssl+自定义用户名密码
  • 原文地址:https://www.cnblogs.com/candy99/p/6068068.html
Copyright © 2020-2023  润新知