zoukankan      html  css  js  c++  java
  • POJ3468(线段树区间维护)

    A Simple Problem with Integers
    Time Limit: 5000MS   Memory Limit: 131072K
    Total Submissions: 85502   Accepted: 26556
    Case Time Limit: 2000MS

    Description

    You have N integers, A1A2, ... , AN. You need to deal with two kinds of operations. One type of operation is to add some given number to each number in a given interval. The other is to ask for the sum of numbers in a given interval.

    Input

    The first line contains two numbers N and Q. 1 ≤ N,Q ≤ 100000.
    The second line contains N numbers, the initial values of A1A2, ... , AN. -1000000000 ≤ Ai ≤ 1000000000.
    Each of the next Q lines represents an operation.
    "C a b c" means adding c to each of AaAa+1, ... , Ab. -10000 ≤ c ≤ 10000.
    "Q a b" means querying the sum of AaAa+1, ... , Ab.

    Output

    You need to answer all Q commands in order. One answer in a line.

    Sample Input

    10 5
    1 2 3 4 5 6 7 8 9 10
    Q 4 4
    Q 1 10
    Q 2 4
    C 3 6 3
    Q 2 4
    

    Sample Output

    4
    55
    9
    15

    线段树入门题。
    #include <cstdio>
    using namespace std;
    const int MAXN = 100005;
    typedef long long LL;
    struct Node{
        int l, r;
        LL sum, lazy;
    }a[MAXN*3];
    int n, m;
    void build(int rt, int l, int r)
    {
        a[rt].l = l;
        a[rt].r = r;
        a[rt].lazy = 0;
        if(l == r)
        {
            scanf("%I64d", &a[rt].sum);
            return ;
        }
        int mid = (l + r) >> 1;
        build(rt << 1, l, mid);
        build((rt << 1) | 1, mid + 1, r);
        a[rt].sum = a[rt<<1].sum + a[(rt<<1)|1].sum;
    }
    void pushDown(int rt)
    {
        int mid = (a[rt].l + a[rt].r) >> 1;
        a[rt<<1].sum += a[rt].lazy * (mid - a[rt].l + 1);
        a[(rt<<1)|1].sum += a[rt].lazy * (a[rt].r - mid);
        a[rt<<1].lazy += a[rt].lazy;
        a[(rt<<1)|1].lazy += a[rt].lazy;
        a[rt].lazy = 0;
    }
    void update(int rt, int l, int r, int val)
    {
        if(a[rt].l == l && a[rt].r == r)
        {
            a[rt].sum += (LL)val * (r - l + 1);
            a[rt].lazy += (LL)val;
            return ;
        }
        if(a[rt].lazy != 0)
        {
            pushDown(rt);
        }
        int mid = (a[rt].l + a[rt].r) >> 1;
        if(r <= mid)
        {
            update(rt << 1, l, r, val);
        }
        else if(mid < l)
        {
            update((rt << 1) | 1, l, r, val);
        }
        else
        {
            update(rt << 1, l, mid, val);
            update((rt << 1) | 1, mid + 1, r, val);
        }
        a[rt].sum = a[rt<<1].sum + a[(rt<<1)|1].sum;
    }
    LL query(int rt, int l, int r)
    {
        if(a[rt].l == l && a[rt].r == r)
        {
            return a[rt].sum;
        }
        if(a[rt].lazy != 0)
        {
            pushDown(rt);
        }
        int mid = (a[rt].l + a[rt].r) >> 1;
        if(r <= mid)
        {
            return query(rt << 1, l, r);
        }
        else if(mid < l)
        {
            return query((rt << 1) | 1, l, r);
        }
        else
        {
            return query(rt << 1, l, mid) + query((rt << 1) | 1, mid + 1, r);
        }
    }
    int main()
    {
        while(scanf("%d %d",&n, &m) != EOF)
        {
            build(1, 1, n);
            while(m--)
            {
                scanf("%*c");
                char op;
                scanf("%c", &op);
                if(op == 'Q')
                {
                    int l, r;
                    scanf("%d %d", &l, &r);
                    printf("%I64d
    ", query(1, l, r));
                }
                else
                {
                    int l, r, val;
                    scanf("%d %d %d", &l, &r ,&val);
                    update(1, l, r, val);
                }
            }
        }
        return 0;
    }
  • 相关阅读:
    Unix Domain Socket(基于 Linux-2.4.0已更新)
    Eclipse常用设置及部分常用快捷键个人总结(MyEclipse通用)
    使用Docker安装ElasticSearch 以及我遇到的问题
    使用Docker安装MySQL
    es 索引自动删除
    k8s部署zk集群
    k8s-基于Canal来定义网络策略
    Markdown学习
    python ---- Linux压缩某个目录但要跳过指定文件
    WEB前端 ---- 学习第二天(表格、表单、css等)
  • 原文地址:https://www.cnblogs.com/program-ccc/p/4941955.html
Copyright © 2011-2022 走看看